| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272 |
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="UTF-8">
- <title>后台管理-登陆</title>
- <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
- <meta http-equiv="Access-Control-Allow-Origin" content="*">
- <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
- <meta name="apple-mobile-web-app-status-bar-style" content="black">
- <meta name="apple-mobile-web-app-capable" content="yes">
- <meta name="format-detection" content="telephone=no">
- <link rel="stylesheet" href="../lib/layui-v2.6.3/css/layui.css" media="all">
- <!--[if lt IE 9]>
- <script src="https://cdn.staticfile.org/html5shiv/r29/html5.min.js"></script>
- <script src="https://cdn.staticfile.org/respond.js/1.4.2/respond.min.js"></script>
- <![endif]-->
- <style>
- .main-body {top:50%;left:50%;position:absolute;-webkit-transform:translate(-50%,-50%);-moz-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);-o-transform:translate(-50%,-50%);transform:translate(-50%,-50%);overflow:hidden;}
- .login-main .login-bottom .center .item input {display:inline-block;width:227px;height:22px;padding:0;position:absolute;border:0;outline:0;font-size:14px;letter-spacing:0;}
- .login-main .login-bottom .center .item .icon-1 {background:url(../images/icon-login.png) no-repeat 1px 0;}
- .login-main .login-bottom .center .item .icon-2 {background:url(../images/icon-login.png) no-repeat -54px 0;}
- .login-main .login-bottom .center .item .icon-3 {background:url(../images/icon-login.png) no-repeat -106px 0;}
- .login-main .login-bottom .center .item .icon-4 {background:url(../images/icon-login.png) no-repeat 0 -43px;position:absolute;right:-10px;cursor:pointer;}
- .login-main .login-bottom .center .item .icon-5 {background:url(../images/icon-login.png) no-repeat -55px -43px;}
- .login-main .login-bottom .center .item .icon-6 {background:url(../images/icon-login.png) no-repeat 0 -93px;position:absolute;right:-10px;margin-top:8px;cursor:pointer;}
- .login-main .login-bottom .tip .icon-nocheck {display:inline-block;width:10px;height:10px;border-radius:2px;border:solid 1px #9abcda;position:relative;top:2px;margin:1px 8px 1px 1px;cursor:pointer;}
- .login-main .login-bottom .tip .icon-check {margin:0 7px 0 0;width:14px;height:14px;border:none;background:url(../images/icon-login.png) no-repeat -111px -48px;}
- .login-main .login-bottom .center .item .icon {display:inline-block;width:33px;height:22px;}
- .login-main .login-bottom .center .item {width:288px;height:35px;border-bottom:1px solid #dae1e6;margin-bottom:35px;}
- .login-main {width:428px;position:relative;float:left;}
- .login-main .login-top {height:117px;background-color:#148be4;border-radius:12px 12px 0 0;font-family:SourceHanSansCN-Regular;font-size:30px;font-weight:400;font-stretch:normal;letter-spacing:0;color:#fff;line-height:117px;text-align:center;overflow:hidden;-webkit-transform:rotate(0);-moz-transform:rotate(0);-ms-transform:rotate(0);-o-transform:rotate(0);transform:rotate(0);}
- .login-main .login-top .bg1 {display:inline-block;width:74px;height:74px;background:#fff;opacity:.1;border-radius:0 74px 0 0;position:absolute;left:0;top:43px;}
- .login-main .login-top .bg2 {display:inline-block;width:94px;height:94px;background:#fff;opacity:.1;border-radius:50%;position:absolute;right:-16px;top:-16px;}
- .login-main .login-bottom {width:428px;background:#fff;border-radius:0 0 12px 12px;padding-bottom:53px;}
- .login-main .login-bottom .center {width:288px;margin:0 auto;padding-top:40px;padding-bottom:15px;position:relative;}
- .login-main .login-bottom .tip {clear:both;height:16px;line-height:16px;width:288px;margin:0 auto;}
- body {background:url(../images/loginbg.png) 0% 0% / cover no-repeat;position:static;font-size:12px;}
- input::-webkit-input-placeholder {color:#a6aebf;}
- input::-moz-placeholder {/* Mozilla Firefox 19+ */ color:#a6aebf;}
- input:-moz-placeholder {/* Mozilla Firefox 4 to 18 */ color:#a6aebf;}
- input:-ms-input-placeholder {/* Internet Explorer 10-11 */ color:#a6aebf;}
- input:-webkit-autofill {/* 取消Chrome记住密码的背景颜色 */ box-shadow:0 0 0 1000px white inset !important;}
- html {height:100%;}
- .login-main .login-bottom .tip {clear:both;height:16px;line-height:16px;width:288px;margin:0 auto;}
- .login-main .login-bottom .tip .login-tip {font-family:MicrosoftYaHei;font-size:12px;font-weight:400;font-stretch:normal;letter-spacing:0;color:#9abcda;cursor:pointer;}
- .login-main .login-bottom .tip .forget-password {font-stretch:normal;letter-spacing:0;color:#1391ff;text-decoration:none;position:absolute;right:62px;}
- .login-main .login-bottom .login-btn {width:288px;height:40px;background-color:#1E9FFF;border-radius:16px;margin:24px auto 0;text-align:center;line-height:40px;color:#fff;font-size:14px;letter-spacing:0;cursor:pointer;border:none;}
- .login-main .login-bottom .center .item .validateImg {position:absolute;right:1px;cursor:pointer;height:36px;border:1px solid #e6e6e6;}
- .footer {left:0;bottom:0;color:#fff;width:100%;position:absolute;text-align:center;line-height:30px;padding-bottom:10px;text-shadow:#000 0.1em 0.1em 0.1em;font-size:14px;}
- .padding-5 {padding:5px !important;}
- .footer a,.footer span {color:#fff;}
- @media screen and (max-width:428px) {.login-main {width:360px !important;}
- .login-main .login-top {width:360px !important;}
- .login-main .login-bottom {width:360px !important;}
- }
- </style>
- </head>
- <body>
- <div class="main-body">
- <div class="login-main">
- <div class="login-top">
- <span>智能弓箭-后台登录</span>
- <span class="bg1"></span>
- <span class="bg2"></span>
- </div>
- <form class="layui-form login-bottom">
- <div class="center">
- <div class="item">
- <select name="serverIndex" lay-filter="serverIndex-selector">
- <option value="0">中国区</option>
- <option value="1">海外区</option>
- </select>
- </div>
-
- <div class="item">
- <span class="icon icon-2"></span>
- <input type="text" name="username" lay-verify="required" placeholder="请输入登录账号" maxlength="24"/>
- </div>
- <div class="item">
- <span class="icon icon-3"></span>
- <input type="password" name="password" lay-verify="required" placeholder="请输入密码" maxlength="20">
- <span class="bind-password icon icon-4"></span>
- </div>
- <div id="validatePanel" class="item" style="width: 137px;">
- <input type="text" name="captcha" placeholder="请输入验证码" maxlength="4">
- <img id="refreshCaptcha" class="validateImg">
- </div>
- </div>
- <div class="tip">
- <span class="icon-nocheck icon-check" id="icon-ccc"></span>
- <span class="login-tip">保持登录</span>
- <!-- <a href="javascript:" class="forget-password">忘记密码?</a> -->
- </div>
- <div class="layui-form-item" style="text-align:center; width:100%;height:100%;margin:0px;">
- <button type="button" class="login-btn" lay-submit="" lay-filter="login">立即登录</button>
- </div>
- </form>
- </div>
- </div>
- <!-- <div class="footer">
- ©版权所有 2014-2018 叁贰柒工作室<span class="padding-5">|</span><a target="_blank" href="http://www.miitbeian.gov.cn">粤ICP备16006642号-2</a>
- </div> -->
- <script src="../lib/layui-v2.6.3/layui.js" charset="utf-8"></script>
- <script src="../lib/jquery-3.4.1/jquery-3.4.1.min.js"></script>
- <script src="../src/js/myConfig.js"></script>
- <script>
- // 获取浏览器类型
- function getBrowserType() {
- // 获取浏览器 userAgent
- let ua = navigator.userAgent
- // 是否为 Opera
- let isOpera = ua.indexOf('Opera') > -1
- // 返回结果
- if (isOpera) { return 'Opera' }
- // 是否为 IE
- let isIE = (ua.indexOf('compatible') > -1) && (ua.indexOf('MSIE') > -1) && !isOpera
- let isIE11 = (ua.indexOf('Trident') > -1) && (ua.indexOf("rv:11.0") > -1)
- // 返回结果
- if (isIE11) { return 'IE11'
- } else if (isIE) {
- // 检测是否匹配
- let re = new RegExp('MSIE (\\d+\\.\\d+);')
- re.test(ua)
- // 获取版本
- let ver = parseFloat(RegExp["$1"])
- // 返回结果
- if (ver == 7) { return 'IE7'
- } else if (ver == 8) { return 'IE8'
- } else if (ver == 9) { return 'IE9'
- } else if (ver == 10) { return 'IE10'
- } else { return "IE" }
- }
- // 是否为 Edge
- let isEdge = ua.indexOf("Edge") > -1
- // 返回结果
- if (isEdge) { return 'Edge' }
- // 是否为 Firefox
- let isFirefox = ua.indexOf("Firefox") > -1
- // 返回结果
- if (isFirefox) { return 'Firefox' }
- let isWX = navigator.userAgent.toLowerCase().includes("wechat")
- if (isWX) { return 'WeChat' }
- // 是否为 UC
- let isUC= ua.indexOf("UCBrowser") > -1
- // 返回结果
- if (isUC) { return 'UC' }
- // 是否为 QQ
- let isQQ= ua.indexOf("QQBrowser") > -1
- // 返回结果
- if (isUC) { return 'QQ' }
- // 是否为 Safari
- let isSafari = (ua.indexOf("Safari") > -1) && (ua.indexOf("Chrome") == -1)
- // 返回结果
- if (isSafari) { return "Safari" }
- // 是否为 Chrome
- let isChrome = (ua.indexOf("Chrome") > -1) && (ua.indexOf("Safari") > -1) && (ua.indexOf("Edge") == -1)
- // 返回结果
- if (isChrome) { return 'Chrome' }
- // 都不是
- return 'Unknown'
- }
- </script>
- <script src="https://pv.sohu.com/cityjson?ie=utf-8"></script><!-- 搜狐api-获取ip和地区 -->
- <script>
- //获取user用户信息(浏览器类型、IP地址、地区)
- function getUserMsg() {
- let userMsgList = [];
- userMsgList.push(getBrowserType());
- if (window["returnCitySN"]) {
- userMsgList.push(returnCitySN["cip"] ?? "IP未知");
- userMsgList.push(returnCitySN["cname"] ?? "地区未知");
- }
- return userMsgList.join(" ");
- }
- </script>
- <script>
- layui.use(['form','jquery'], function () {
- var $ = layui.jquery,
- form = layui.form,
- layer = layui.layer;
- // 登录过期的时候,跳出ifram框架
- if (top.location != self.location) top.location = self.location;
- $('.bind-password').on('click', function () {
- if ($(this).hasClass('icon-5')) {
- $(this).removeClass('icon-5');
- $("input[name='password']").attr('type', 'password');
- } else {
- $(this).addClass('icon-5');
- $("input[name='password']").attr('type', 'text');
- }
- });
- $('.icon-nocheck').on('click', function () {
- if ($(this).hasClass('icon-check')) {
- $(this).removeClass('icon-check');
- } else {
- $(this).addClass('icon-check');
- }
- });
- // 进行登录操作
- form.on('submit(login)', function (data) {
- data = data.field;
- if (data.username == '') {
- layer.msg('用户名不能为空');
- return false;
- }
- if (data.password == '') {
- layer.msg('密码不能为空');
- return false;
- }
- if (data.captcha == '') {
- layer.msg('验证码不能为空');
- return false;
- }
- if (data.captcha != captchaCode) {
- layer.msg('验证码不正确')
- return false;
- }
- window.setServerIndex(data.serverIndex);
- requestAPI({
- url: "/admin/admin/login",
- type: "POST",
- data: {
- username: data.username,
- password: data.password,
- userMsg: getUserMsg()
- },
- success: (data) => {
- if (data.code == 0) {
- let token = data.data;
- let tokenKeep = $("#icon-ccc").hasClass('icon-check');
- window.saveLoginAuth(token, tokenKeep);
- layer.msg("登录成功", {time: 600},function () {
- window.location = '../index.html?v=' + Date.now();
- });
- } else {
- layer.msg(data.msg);
- }
- }
- });
- return false;
- });
- });
- //验证码
- var captchaCode = 2222222222222222;
- function refreshCaptcha() {
- captchaCode = 1000 + Math.floor(Math.random() * 9000);
- getBinary(window.getNewServerURL() + "/api/createCaptcha", {code: captchaCode}, (res) => {
- $("#refreshCaptcha").attr("src", URL.createObjectURL(res));
- });
- }
- $("#refreshCaptcha").on("click", refreshCaptcha);
- refreshCaptcha();
- </script>
- </body>
- </html>
|