返回列表 上一筆 下一筆

目前格式:HTML/XML

🧾 資料內容 (HTML/XML)

<!doctype html>
<html xmlns:th="http://www.thymeleaf.org" xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
	layout:decorate="~{layout/layout}">

<head>
	<meta http-equiv="REFRESH" content="600">
	<style type="text/css" th:nonce="${nonce}">
		.overlay {
			position: fixed;
			width: 100%;
			height: 100%;
			left: 0;
			top: 0;
			background: rgba(51, 51, 51, 0.7);
			z-index: 10;
		}

		.stealthy {
			left: 0;
			margin: 0;
			max-height: 1px;
			max-width: 1px;
			opacity: 0;
			outline: none;
			overflow: hidden;
			pointer-events: none;
			position: absolute;
			top: 0;
			z-index: -1;
		}

		.loginFixInline1 {
			background-color: #FFF;
		}

		.loginFixInline10 {
			border-bottom: 1px #45a19a solid !important;
			border-top: 0px !important;
			border-left: 0px !important;
			border-right: 0px !important;
			font-size: 15px !important;
			width: 220px !important;
		}

		.loginFixInline11 {
			float: right;
			padding-right: 40px;
		}

		.loginFixInline12 {
			float: left;
			padding-right: 10px;
			padding-top: 5px;
		}

		.loginFixInline13 {
			float: left;
			padding-top: -5px;
		}

		.loginFixInline14 {
			float: left;
			font-size: 18px;
			color: #333333;
			font-weight: bold;
			line-height: 60px;
			padding-top: 30px;
		}

		#loginFixInline15 {
			border-bottom: 1px #45a19a solid;
			border-top: 0px;
			border-left: 0px;
			border-right: 0px;
			font-size: 15px;
			width: 218px;
		}

		.loginFixInline16 {
			width: 100%;
			padding-top: 180px;
			font-size: 15px;
			color: #FF0000;
			padding-left: 0px;
		}

		.loginFixInline17 {
			color: red
		}

		.loginFixInline18 {
			width: 50%;
			padding-top: 20px;
		}

		.loginFixInline19 {
			float: left;
			padding-top: 10px;
			width: 150px;
		}

		.loginFixInline2 {
			background-image: url('/images/AgentPorta_indexb00.jpg');
			margin-bottom: -16px;
		}

		.loginFixInline20 {
			line-height: 40px;
		}

		.loginFixInline21 {
			width: 40%;
			padding-top: 10px;
			float: left;
		}

		.loginFixInline22 {
			text-align: left;
			line-height: 24px;
			font-size: 14px;
			color: #666666;
			font-weight: bold;
		}

		.loginFixInline23 {
			text-align: left;
			line-height: 26px;
			font-size: 14px;
			color: #666666;
			font-weight: bold;
			list-style-type: decimal;
			padding-left: 18px;
		}

		.loginFixInline24 {
			padding-right: 10px;
			padding-left: 0px
		}

		.loginFixInline3 {
			background-color: #ececec;
		}

		.loginFixInline4 {
			height: auto;
			max-width: 100%;
			max-height: 100%;
		}

		.loginFixInline5 {
			width: 93%;
			padding-top: 35px;
		}

		.loginFixInline6 {
			float: left;
			width: 450px;
			padding-bottom: 0px;
			background-color: #ececec;
			height: 300px;
		}

		.loginFixInline7 {
			float: left;
			font-size: 18px;
			color: #333333;
			font-weight: bold;
			line-height: 60px;
		}

		.loginFixInline8 {
			float: right;
			border: 0px #007d7d solid;
			width: 380px;
			height: 65px;
			border-radius: 50px;
			padding-left: 35px;
			background-color: #FFFFFF;
		}

		.loginFixInline9 {
			float: left;
		}

		.toggle-visibility {
			position: absolute;
			right: 10px;
			top: 50%;
			transform: translateY(-50%);
			cursor: pointer;
			user-select: none;
		}

		/* 1140301608-00 業務e平台登入頁新增密碼顯示&隱藏功能與各系統timeout時間長度調整。 */
		/* 讓按鈕能絕對定位在容器內 */
		.pw-wrap { position: relative; }

		/* 給真正的密碼框右側留空,避免文字蓋到眼睛 */
		#loginFixInline15 { padding-right: 3rem; } /* 視你的按鈕寬度可調 2.4~3.2rem */

		/* 眼睛按鈕:覆蓋在輸入框裡面右側、垂直置中 */
		.pw-toggle{
		  position:absolute;
		  right: .8rem;                 /* 調這裡可微調與右邊距離 */
		  top: 50%;
		  transform: translateY(-50%);  /* 垂直置中 */
		  width: 28px;                  /* 按鈕寬高可依你輸入框高度調 */
		  height: 28px;
		  border: none;
		  background: transparent;
		  cursor: pointer;
		  padding: 0;
		  line-height: 1;
		  z-index: 1;                   /* 確保覆蓋在輸入框上層 */
		  background-repeat: no-repeat;
		  background-position: left 4px center;  /* 左邊內縮 4px,垂直置中 */
		  background-size: contain;   /* 圖示大小,依需求調整 */
		}

		/* 用 CSS 指 SVG 圖檔路徑(路徑以 CSS 檔案所在目錄為基準) */
		.pw-toggle.eye-open  { background-image: url("/images/eye_open.svg");  }
		.pw-toggle.eye-close { background-image: url("/images/eye_close-01.svg"); }

		/* 鍵盤可見焦點(可選) */
		.pw-toggle:focus { outline: 2px solid #2684ff; outline-offset: 2px; }

	</style>

	<script type="text/javascript" th:nonce="${nonce}">
		$(function(){
		  // 若頁面不只一個「密碼」區塊,也能作用:就近找同容器內的真正輸入框
		  $('.pw-toggle').on('click', function(){
		    var $btn   = $(this);
		    var $wrap  = $btn.closest('.pw-wrap');
		    var $input = $wrap.find('input[data-name="userPassword"]').first();

		    var show = $input.attr('type') === 'password';
		    $input.attr('type', show ? 'text' : 'password');

		    $btn.toggleClass('eye-open eye-close')
		        .attr('aria-pressed', show)
		        .attr('aria-label', show ? '隱藏密碼' : '顯示密碼');

		    $input.trigger('focus');
		  });
		});
	</script>
</head>

<body class="loginFixInline1">
	<div class="container" layout:fragment="content">
		<div id="mask"></div>
		<div class="container loginFixInline2">
			<div class="content-wrap" align="center">
				<!--隱藏menu-->
				<div class="loginFixInline3">
					<div class="">
						<div>
							<img src="/images/AgentPorta_index00_20220601.png"
								th:src="@{/images/AgentPorta_index00_20220601.png}" border="0" class="loginFixInline4">
						</div>
					</div>
				</div>
			</div>
		</div>
		<div class="container loginFixInline3">
			<div class="content-wrap loginFixInline3" align="center">
				<div align="center" class="loginFixInline5">
					<form name="loginForm" id="loginForm" th:action="@{/login}" th:object="${loginForm}" method="POST">
						<input type="hidden" th:name="service" th:value="${service}">
						<div class="loginFixInline6">
							<!--帳號-->
							<div class="loginFixInline7">
								帳號
								<div class="loginFixInline8">
									<div class="loginFixInline9">
										<input type="password" autocomplete="off" class="stealthy" tabindex="-1">
										<!--1100900286-00--> <input type="text" data-name="userID" maxlength="10"
											autocomplete="off" class="loginFixInline10"> <input type="password"
											autocomplete="off" class="stealthy" tabindex="-1">
										<!--1100900286-00-->
									</div>
									<div class="radiobutton-wrap text-left-top loginFixInline11">
										<div class="checkbox-wrap text-left loginFixInline12">
											<input type="checkbox" class="myCheckboxes" name="remembered"
												id="remembered" value="A"><label for="remembered"></label>
										</div>
										<div class="loginFixInline13">
											記住
										</div>
									</div>
								</div>
							</div>
							<div class="loginFixInline14">
							  密碼
							  <div align="left" class="loginFixInline8 pw-wrap">
							    <input type="password" autocomplete="off" class="stealthy" tabindex="-1">

							    <!-- 真正的密碼框 -->
							    <input type="password" data-name="userPassword"
							           autocomplete="off" maxlength="16"
							           id="loginFixInline15" class="loginFixInline10">
							    <input type="password" autocomplete="off" class="stealthy" tabindex="-1">
							    <!-- 眼睛在輸入框內右側:初始為「關眼」 -->
							    <button type="button" class="pw-toggle eye-close"
							            aria-label="顯示密碼" aria-pressed="false"></button>
							  </div>
							</div>
							<br>
							<div class="loginFixInline16">
								<span th:text="${Msg}" class="loginFixInline17"></span>
							</div>
							<div class="loginFixInline18">
								<a id="login" href="#" target="_parent"><img src="../static/images/icon_login01.png"
										th:src="@{/images/icon_login01.png}" alt="登入" title="登入" border="0"></a> <a
									id="clear" href="#" target="_parent"><img src="../static/images/icon_cancel01.png"
										th:src="@{/images/icon_cancel01.png}" alt="清除" title="清除" border="0"></a>
							</div>
						</div>
						<div class="loginFixInline19">
							<a th:href="@{/pdReset/{reLinkPath}(reLinkPath=${T(com.taiwanlife.agentportal.enums.PdResetTypeEnum).FORGET_PD.getType()})}"
								target="_parent" class="loginFixInline20"><img src="/images/icon_forget01.png"
									alt="忘記密碼" title="忘記密碼" border="0"></a>
							<br><a
								th:href="@{/pdReset/{reLinkPath}(reLinkPath=${T(com.taiwanlife.agentportal.enums.PdResetTypeEnum).RESET_ACOUNT.getType()})}"
								target="_parent"><img src="/images/icon_Reset01.png" alt="重啟密碼" title="重啟密碼"
									border="0"></a>
						</div>
					</form>
					<div class="loginFixInline21">
						<ol class="loginFixInline22">
							<li>基於資訊安全原則:</li>
							<ol class="loginFixInline23">
								<li>請每三個月變更密碼。</li>
								<li>密碼輸入連續錯誤五次,系統自動鎖住,請申請忘記密碼解鎖,<br>
									一天內僅可申請五次。</li>
								<li>帳號連續半年未使用,系統自動停用,請申請重啟帳號啟用。</li>
							</ol>
						</ol>
					</div>
				</div>
			</div>
		</div>
		<div class="box-model" id="messageBox">
			<div class="box-alert loginFixInline24">
				<div class="row"></div>
				<div class="text">
					<p class="text-bold text-black"></p>
					<p class="text-bold text-black">系統不支援 IE !</p>
					<p class="text-bold text-black"></p>
				</div>
			</div>
		</div>
	</div>
	<script th:nonce="${nonce}" type="text/javascript" th:inline="javascript" layout:fragment="contentScript">
		//if (top != self)
		//    top.location = encodeURI(self.location);

		function login() {
			$("input[type=text][data-name]").attr("name", $("input[type=text][data-name]").attr("data-name"));
			$("input[type=password][data-name]").attr("name", $("input[type=password][data-name]").attr("data-name"));
			if ($('input[name="remembered"]:checked').length > 0
				&& $("input[type=text][data-name]").val() != "") {
				$.cookie("userId", $("input[type=text][data-name]").val().trim(), {expires: 90, path: "/"});
			} else {
				$.removeCookie("userId");
			}
			// 密碼加密for Payload display
			$("input[type=password][data-name]").val(checkPw($("input[type=password][data-name]").val()));
			$('#loginForm').submit();
		}

		function clear() {
			$("form")[0].reset();
		}

		// Detect IE
		$(window).on("load", function () {
			let currBrowser = detectIE();

			if (currBrowser != false) {
				alert('業務e平台不支援IE瀏覽器');
				document.getElementById('mask').classList.add('overlay');
			}
		});

		$(document).ready(function () {
			$('#clear').on('click', clear);
			$('#login').on('click', login);
			var userId = $.cookie("userId");
			if (userId != undefined) {
				$("input[type=text][data-name]").val(userId);
				$('#remembered').prop("checked", true);
			} else {
				$('#remembered').prop("checked", false);
			}
		});

		var checkPw = function (d) {var r = M(V(Y(X(d), 8 * d.length))); return r.toLowerCase()}; function M(d) {for (var _, m = "0123456789ABCDEF", f = "", r = 0; r < d.length; r++)_ = d.charCodeAt(r), f += m.charAt(_ >>> 4 & 15) + m.charAt(15 & _); return f} function X(d) {for (var _ = Array(d.length >> 2), m = 0; m < _.length; m++)_[m] = 0; for (m = 0; m < 8 * d.length; m += 8)_[m >> 5] |= (255 & d.charCodeAt(m / 8)) << m % 32; return _} function V(d) {for (var _ = "", m = 0; m < 32 * d.length; m += 8)_ += String.fromCharCode(d[m >> 5] >>> m % 32 & 255); return _} function Y(d, _) {d[_ >> 5] |= 128 << _ % 32, d[14 + (_ + 64 >>> 9 << 4)] = _; for (var m = 1732584193, f = -271733879, r = -1732584194, i = 271733878, n = 0; n < d.length; n += 16) {var h = m, t = f, g = r, e = i; f = checkPw_ii(f = checkPw_ii(f = checkPw_ii(f = checkPw_ii(f = checkPw_hh(f = checkPw_hh(f = checkPw_hh(f = checkPw_hh(f = checkPw_gg(f = checkPw_gg(f = checkPw_gg(f = checkPw_gg(f = checkPw_ff(f = checkPw_ff(f = checkPw_ff(f = checkPw_ff(f, r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 0], 7, -680876936), f, r, d[n + 1], 12, -389564586), m, f, d[n + 2], 17, 606105819), i, m, d[n + 3], 22, -1044525330), r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 4], 7, -176418897), f, r, d[n + 5], 12, 1200080426), m, f, d[n + 6], 17, -1473231341), i, m, d[n + 7], 22, -45705983), r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 8], 7, 1770035416), f, r, d[n + 9], 12, -1958414417), m, f, d[n + 10], 17, -42063), i, m, d[n + 11], 22, -1990404162), r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 12], 7, 1804603682), f, r, d[n + 13], 12, -40341101), m, f, d[n + 14], 17, -1502002290), i, m, d[n + 15], 22, 1236535329), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 1], 5, -165796510), f, r, d[n + 6], 9, -1069501632), m, f, d[n + 11], 14, 643717713), i, m, d[n + 0], 20, -373897302), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 5], 5, -701558691), f, r, d[n + 10], 9, 38016083), m, f, d[n + 15], 14, -660478335), i, m, d[n + 4], 20, -405537848), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 9], 5, 568446438), f, r, d[n + 14], 9, -1019803690), m, f, d[n + 3], 14, -187363961), i, m, d[n + 8], 20, 1163531501), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 13], 5, -1444681467), f, r, d[n + 2], 9, -51403784), m, f, d[n + 7], 14, 1735328473), i, m, d[n + 12], 20, -1926607734), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 5], 4, -378558), f, r, d[n + 8], 11, -2022574463), m, f, d[n + 11], 16, 1839030562), i, m, d[n + 14], 23, -35309556), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 1], 4, -1530992060), f, r, d[n + 4], 11, 1272893353), m, f, d[n + 7], 16, -155497632), i, m, d[n + 10], 23, -1094730640), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 13], 4, 681279174), f, r, d[n + 0], 11, -358537222), m, f, d[n + 3], 16, -722521979), i, m, d[n + 6], 23, 76029189), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 9], 4, -640364487), f, r, d[n + 12], 11, -421815835), m, f, d[n + 15], 16, 530742520), i, m, d[n + 2], 23, -995338651), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 0], 6, -198630844), f, r, d[n + 7], 10, 1126891415), m, f, d[n + 14], 15, -1416354905), i, m, d[n + 5], 21, -57434055), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 12], 6, 1700485571), f, r, d[n + 3], 10, -1894986606), m, f, d[n + 10], 15, -1051523), i, m, d[n + 1], 21, -2054922799), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 8], 6, 1873313359), f, r, d[n + 15], 10, -30611744), m, f, d[n + 6], 15, -1560198380), i, m, d[n + 13], 21, 1309151649), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 4], 6, -145523070), f, r, d[n + 11], 10, -1120210379), m, f, d[n + 2], 15, 718787259), i, m, d[n + 9], 21, -343485551), m = safe_add(m, h), f = safe_add(f, t), r = safe_add(r, g), i = safe_add(i, e)} return Array(m, f, r, i)} function checkPw_cmn(d, _, m, f, r, i) {return safe_add(bit_rol(safe_add(safe_add(_, d), safe_add(f, i)), r), m)} function checkPw_ff(d, _, m, f, r, i, n) {return checkPw_cmn(_ & m | ~_ & f, d, _, r, i, n)} function checkPw_gg(d, _, m, f, r, i, n) {return checkPw_cmn(_ & f | m & ~f, d, _, r, i, n)} function checkPw_hh(d, _, m, f, r, i, n) {return checkPw_cmn(_ ^ m ^ f, d, _, r, i, n)} function checkPw_ii(d, _, m, f, r, i, n) {return checkPw_cmn(m ^ (_ | ~f), d, _, r, i, n)} function safe_add(d, _) {var m = (65535 & d) + (65535 & _); return (d >> 16) + (_ >> 16) + (m >> 16) << 16 | 65535 & m} function bit_rol(d, _) {return d << _ | d >>> 32 - _}
	</script>
</body>

</html>

🔐 Base64 編碼內容

<!doctype html>
<html xmlns:th="http://www.thymeleaf.org" xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
	layout:decorate="~{layout/layout}">

<head>
	<meta http-equiv="REFRESH" content="600">
	<style type="text/css" th:nonce="${nonce}">
		.overlay {
			position: fixed;
			width: 100%;
			height: 100%;
			left: 0;
			top: 0;
			background: rgba(51, 51, 51, 0.7);
			z-index: 10;
		}

		.stealthy {
			left: 0;
			margin: 0;
			max-height: 1px;
			max-width: 1px;
			opacity: 0;
			outline: none;
			overflow: hidden;
			pointer-events: none;
			position: absolute;
			top: 0;
			z-index: -1;
		}

		.loginFixInline1 {
			background-color: #FFF;
		}

		.loginFixInline10 {
			border-bottom: 1px #45a19a solid !important;
			border-top: 0px !important;
			border-left: 0px !important;
			border-right: 0px !important;
			font-size: 15px !important;
			width: 220px !important;
		}

		.loginFixInline11 {
			float: right;
			padding-right: 40px;
		}

		.loginFixInline12 {
			float: left;
			padding-right: 10px;
			padding-top: 5px;
		}

		.loginFixInline13 {
			float: left;
			padding-top: -5px;
		}

		.loginFixInline14 {
			float: left;
			font-size: 18px;
			color: #333333;
			font-weight: bold;
			line-height: 60px;
			padding-top: 30px;
		}

		#loginFixInline15 {
			border-bottom: 1px #45a19a solid;
			border-top: 0px;
			border-left: 0px;
			border-right: 0px;
			font-size: 15px;
			width: 218px;
		}

		.loginFixInline16 {
			width: 100%;
			padding-top: 180px;
			font-size: 15px;
			color: #FF0000;
			padding-left: 0px;
		}

		.loginFixInline17 {
			color: red
		}

		.loginFixInline18 {
			width: 50%;
			padding-top: 20px;
		}

		.loginFixInline19 {
			float: left;
			padding-top: 10px;
			width: 150px;
		}

		.loginFixInline2 {
			background-image: url('/images/AgentPorta_indexb00.jpg');
			margin-bottom: -16px;
		}

		.loginFixInline20 {
			line-height: 40px;
		}

		.loginFixInline21 {
			width: 40%;
			padding-top: 10px;
			float: left;
		}

		.loginFixInline22 {
			text-align: left;
			line-height: 24px;
			font-size: 14px;
			color: #666666;
			font-weight: bold;
		}

		.loginFixInline23 {
			text-align: left;
			line-height: 26px;
			font-size: 14px;
			color: #666666;
			font-weight: bold;
			list-style-type: decimal;
			padding-left: 18px;
		}

		.loginFixInline24 {
			padding-right: 10px;
			padding-left: 0px
		}

		.loginFixInline3 {
			background-color: #ececec;
		}

		.loginFixInline4 {
			height: auto;
			max-width: 100%;
			max-height: 100%;
		}

		.loginFixInline5 {
			width: 93%;
			padding-top: 35px;
		}

		.loginFixInline6 {
			float: left;
			width: 450px;
			padding-bottom: 0px;
			background-color: #ececec;
			height: 300px;
		}

		.loginFixInline7 {
			float: left;
			font-size: 18px;
			color: #333333;
			font-weight: bold;
			line-height: 60px;
		}

		.loginFixInline8 {
			float: right;
			border: 0px #007d7d solid;
			width: 380px;
			height: 65px;
			border-radius: 50px;
			padding-left: 35px;
			background-color: #FFFFFF;
		}

		.loginFixInline9 {
			float: left;
		}

		.toggle-visibility {
			position: absolute;
			right: 10px;
			top: 50%;
			transform: translateY(-50%);
			cursor: pointer;
			user-select: none;
		}
		
		/* 1140301608-00 業務e平台登入頁新增密碼顯示&隱藏功能與各系統timeout時間長度調整。 */
		/* 讓按鈕能絕對定位在容器內 */
		.pw-wrap { position: relative; }

		/* 給真正的密碼框右側留空，避免文字蓋到眼睛 */
		#loginFixInline15 { padding-right: 3rem; } /* 視你的按鈕寬度可調 2.4~3.2rem */

		/* 眼睛按鈕：覆蓋在輸入框裡面右側、垂直置中 */
		.pw-toggle{
		  position:absolute;
		  right: .8rem;                 /* 調這裡可微調與右邊距離 */
		  top: 50%;
		  transform: translateY(-50%);  /* 垂直置中 */
		  width: 28px;                  /* 按鈕寬高可依你輸入框高度調 */
		  height: 28px;
		  border: none;
		  background: transparent;
		  cursor: pointer;
		  padding: 0;
		  line-height: 1;
		  z-index: 1;                   /* 確保覆蓋在輸入框上層 */
		  background-repeat: no-repeat;
		  background-position: left 4px center;  /* 左邊內縮 4px，垂直置中 */
		  background-size: contain;   /* 圖示大小，依需求調整 */
		}

		/* 用 CSS 指 SVG 圖檔路徑（路徑以 CSS 檔案所在目錄為基準） */
		.pw-toggle.eye-open  { background-image: url("/images/eye_open.svg");  }
		.pw-toggle.eye-close { background-image: url("/images/eye_close-01.svg"); }

		/* 鍵盤可見焦點（可選） */
		.pw-toggle:focus { outline: 2px solid #2684ff; outline-offset: 2px; }
		
	</style>

	<script type="text/javascript" th:nonce="${nonce}">
		$(function(){
		  // 若頁面不只一個「密碼」區塊，也能作用：就近找同容器內的真正輸入框
		  $('.pw-toggle').on('click', function(){
		    var $btn   = $(this);
		    var $wrap  = $btn.closest('.pw-wrap');
		    var $input = $wrap.find('input[data-name="userPassword"]').first();

		    var show = $input.attr('type') === 'password';
		    $input.attr('type', show ? 'text' : 'password');

		    $btn.toggleClass('eye-open eye-close')
		        .attr('aria-pressed', show)
		        .attr('aria-label', show ? '隱藏密碼' : '顯示密碼');

		    $input.trigger('focus');
		  });
		});
	</script>
</head>

<body class="loginFixInline1">
	<div class="container" layout:fragment="content">
		<div id="mask"></div>
		<div class="container loginFixInline2">
			<div class="content-wrap" align="center">
				<!--隱藏menu-->
				<div class="loginFixInline3">
					<div class="">
						<div>
							<img src="/images/AgentPorta_index00_20220601.png"
								th:src="@{/images/AgentPorta_index00_20220601.png}" border="0" class="loginFixInline4">
						</div>
					</div>
				</div>
			</div>
		</div>
		<div class="container loginFixInline3">
			<div class="content-wrap loginFixInline3" align="center">
				<div align="center" class="loginFixInline5">
					<form name="loginForm" id="loginForm" th:action="@{/login}" th:object="${loginForm}" method="POST">
						<input type="hidden" th:name="service" th:value="${service}">
						<div class="loginFixInline6">
							<!--帳號-->
							<div class="loginFixInline7">
								帳號　
								<div class="loginFixInline8">
									<div class="loginFixInline9">
										<input type="password" autocomplete="off" class="stealthy" tabindex="-1">
										<!--1100900286-00--> <input type="text" data-name="userID" maxlength="10"
											autocomplete="off" class="loginFixInline10"> <input type="password"
											autocomplete="off" class="stealthy" tabindex="-1">
										<!--1100900286-00-->
									</div>
									<div class="radiobutton-wrap text-left-top loginFixInline11">
										<div class="checkbox-wrap text-left loginFixInline12">
											<input type="checkbox" class="myCheckboxes" name="remembered"
												id="remembered" value="A"><label for="remembered"></label>
										</div>
										<div class="loginFixInline13">
											記住
										</div>
									</div>
								</div>
							</div>
							<div class="loginFixInline14">
							  密碼
							  <div align="left" class="loginFixInline8 pw-wrap">
							    <input type="password" autocomplete="off" class="stealthy" tabindex="-1">

							    <!-- 真正的密碼框 -->
							    <input type="password" data-name="userPassword"
							           autocomplete="off" maxlength="16"
							           id="loginFixInline15" class="loginFixInline10">
							    <input type="password" autocomplete="off" class="stealthy" tabindex="-1">
							    <!-- 眼睛在輸入框內右側：初始為「關眼」 -->
							    <button type="button" class="pw-toggle eye-close"
							            aria-label="顯示密碼" aria-pressed="false"></button>
							  </div>
							</div>
							<br>
							<div class="loginFixInline16">
								<span th:text="${Msg}" class="loginFixInline17"></span>
							</div>
							<div class="loginFixInline18">
								<a id="login" href="#" target="_parent"><img src="../static/images/icon_login01.png"
										th:src="@{/images/icon_login01.png}" alt="登入" title="登入" border="0"></a> <a
									id="clear" href="#" target="_parent"><img src="../static/images/icon_cancel01.png"
										th:src="@{/images/icon_cancel01.png}" alt="清除" title="清除" border="0"></a>
							</div>
						</div>
						<div class="loginFixInline19">
							<a th:href="@{/pdReset/{reLinkPath}(reLinkPath=${T(com.taiwanlife.agentportal.enums.PdResetTypeEnum).FORGET_PD.getType()})}"
								target="_parent" class="loginFixInline20"><img src="/images/icon_forget01.png"
									alt="忘記密碼" title="忘記密碼" border="0"></a>
							<br><a
								th:href="@{/pdReset/{reLinkPath}(reLinkPath=${T(com.taiwanlife.agentportal.enums.PdResetTypeEnum).RESET_ACOUNT.getType()})}"
								target="_parent"><img src="/images/icon_Reset01.png" alt="重啟密碼" title="重啟密碼"
									border="0"></a>
						</div>
					</form>
					<div class="loginFixInline21">
						<ol class="loginFixInline22">
							<li>基於資訊安全原則：</li>
							<ol class="loginFixInline23">
								<li>請每三個月變更密碼。</li>
								<li>密碼輸入連續錯誤五次，系統自動鎖住，請申請忘記密碼解鎖，<br>
									一天內僅可申請五次。</li>
								<li>帳號連續半年未使用，系統自動停用，請申請重啟帳號啟用。</li>
							</ol>
						</ol>
					</div>
				</div>
			</div>
		</div>
		<div class="box-model" id="messageBox">
			<div class="box-alert loginFixInline24">
				<div class="row"></div>
				<div class="text">
					<p class="text-bold text-black"></p>
					<p class="text-bold text-black">系統不支援 IE !</p>
					<p class="text-bold text-black"></p>
				</div>
			</div>
		</div>
	</div>
	<script th:nonce="${nonce}" type="text/javascript" th:inline="javascript" layout:fragment="contentScript">
		//if (top != self)
		//    top.location = encodeURI(self.location);

		function login() {
			$("input[type=text][data-name]").attr("name", $("input[type=text][data-name]").attr("data-name"));
			$("input[type=password][data-name]").attr("name", $("input[type=password][data-name]").attr("data-name"));
			if ($('input[name="remembered"]:checked').length > 0
				&& $("input[type=text][data-name]").val() != "") {
				$.cookie("userId", $("input[type=text][data-name]").val().trim(), {expires: 90, path: "/"});
			} else {
				$.removeCookie("userId");
			}
			// 密碼加密for Payload display
			$("input[type=password][data-name]").val(checkPw($("input[type=password][data-name]").val()));
			$('#loginForm').submit();
		}

		function clear() {
			$("form")[0].reset();
		}

		// Detect IE
		$(window).on("load", function () {
			let currBrowser = detectIE();

			if (currBrowser != false) {
				alert('業務e平台不支援IE瀏覽器');
				document.getElementById('mask').classList.add('overlay');
			}
		});

		$(document).ready(function () {
			$('#clear').on('click', clear);
			$('#login').on('click', login);
			var userId = $.cookie("userId");
			if (userId != undefined) {
				$("input[type=text][data-name]").val(userId);
				$('#remembered').prop("checked", true);
			} else {
				$('#remembered').prop("checked", false);
			}
		});

		var checkPw = function (d) {var r = M(V(Y(X(d), 8 * d.length))); return r.toLowerCase()}; function M(d) {for (var _, m = "0123456789ABCDEF", f = "", r = 0; r < d.length; r++)_ = d.charCodeAt(r), f += m.charAt(_ >>> 4 & 15) + m.charAt(15 & _); return f} function X(d) {for (var _ = Array(d.length >> 2), m = 0; m < _.length; m++)_[m] = 0; for (m = 0; m < 8 * d.length; m += 8)_[m >> 5] |= (255 & d.charCodeAt(m / 8)) << m % 32; return _} function V(d) {for (var _ = "", m = 0; m < 32 * d.length; m += 8)_ += String.fromCharCode(d[m >> 5] >>> m % 32 & 255); return _} function Y(d, _) {d[_ >> 5] |= 128 << _ % 32, d[14 + (_ + 64 >>> 9 << 4)] = _; for (var m = 1732584193, f = -271733879, r = -1732584194, i = 271733878, n = 0; n < d.length; n += 16) {var h = m, t = f, g = r, e = i; f = checkPw_ii(f = checkPw_ii(f = checkPw_ii(f = checkPw_ii(f = checkPw_hh(f = checkPw_hh(f = checkPw_hh(f = checkPw_hh(f = checkPw_gg(f = checkPw_gg(f = checkPw_gg(f = checkPw_gg(f = checkPw_ff(f = checkPw_ff(f = checkPw_ff(f = checkPw_ff(f, r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 0], 7, -680876936), f, r, d[n + 1], 12, -389564586), m, f, d[n + 2], 17, 606105819), i, m, d[n + 3], 22, -1044525330), r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 4], 7, -176418897), f, r, d[n + 5], 12, 1200080426), m, f, d[n + 6], 17, -1473231341), i, m, d[n + 7], 22, -45705983), r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 8], 7, 1770035416), f, r, d[n + 9], 12, -1958414417), m, f, d[n + 10], 17, -42063), i, m, d[n + 11], 22, -1990404162), r = checkPw_ff(r, i = checkPw_ff(i, m = checkPw_ff(m, f, r, i, d[n + 12], 7, 1804603682), f, r, d[n + 13], 12, -40341101), m, f, d[n + 14], 17, -1502002290), i, m, d[n + 15], 22, 1236535329), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 1], 5, -165796510), f, r, d[n + 6], 9, -1069501632), m, f, d[n + 11], 14, 643717713), i, m, d[n + 0], 20, -373897302), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 5], 5, -701558691), f, r, d[n + 10], 9, 38016083), m, f, d[n + 15], 14, -660478335), i, m, d[n + 4], 20, -405537848), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 9], 5, 568446438), f, r, d[n + 14], 9, -1019803690), m, f, d[n + 3], 14, -187363961), i, m, d[n + 8], 20, 1163531501), r = checkPw_gg(r, i = checkPw_gg(i, m = checkPw_gg(m, f, r, i, d[n + 13], 5, -1444681467), f, r, d[n + 2], 9, -51403784), m, f, d[n + 7], 14, 1735328473), i, m, d[n + 12], 20, -1926607734), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 5], 4, -378558), f, r, d[n + 8], 11, -2022574463), m, f, d[n + 11], 16, 1839030562), i, m, d[n + 14], 23, -35309556), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 1], 4, -1530992060), f, r, d[n + 4], 11, 1272893353), m, f, d[n + 7], 16, -155497632), i, m, d[n + 10], 23, -1094730640), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 13], 4, 681279174), f, r, d[n + 0], 11, -358537222), m, f, d[n + 3], 16, -722521979), i, m, d[n + 6], 23, 76029189), r = checkPw_hh(r, i = checkPw_hh(i, m = checkPw_hh(m, f, r, i, d[n + 9], 4, -640364487), f, r, d[n + 12], 11, -421815835), m, f, d[n + 15], 16, 530742520), i, m, d[n + 2], 23, -995338651), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 0], 6, -198630844), f, r, d[n + 7], 10, 1126891415), m, f, d[n + 14], 15, -1416354905), i, m, d[n + 5], 21, -57434055), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 12], 6, 1700485571), f, r, d[n + 3], 10, -1894986606), m, f, d[n + 10], 15, -1051523), i, m, d[n + 1], 21, -2054922799), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 8], 6, 1873313359), f, r, d[n + 15], 10, -30611744), m, f, d[n + 6], 15, -1560198380), i, m, d[n + 13], 21, 1309151649), r = checkPw_ii(r, i = checkPw_ii(i, m = checkPw_ii(m, f, r, i, d[n + 4], 6, -145523070), f, r, d[n + 11], 10, -1120210379), m, f, d[n + 2], 15, 718787259), i, m, d[n + 9], 21, -343485551), m = safe_add(m, h), f = safe_add(f, t), r = safe_add(r, g), i = safe_add(i, e)} return Array(m, f, r, i)} function checkPw_cmn(d, _, m, f, r, i) {return safe_add(bit_rol(safe_add(safe_add(_, d), safe_add(f, i)), r), m)} function checkPw_ff(d, _, m, f, r, i, n) {return checkPw_cmn(_ & m | ~_ & f, d, _, r, i, n)} function checkPw_gg(d, _, m, f, r, i, n) {return checkPw_cmn(_ & f | m & ~f, d, _, r, i, n)} function checkPw_hh(d, _, m, f, r, i, n) {return checkPw_cmn(_ ^ m ^ f, d, _, r, i, n)} function checkPw_ii(d, _, m, f, r, i, n) {return checkPw_cmn(m ^ (_ | ~f), d, _, r, i, n)} function safe_add(d, _) {var m = (65535 & d) + (65535 & _); return (d >> 16) + (_ >> 16) + (m >> 16) << 16 | 65535 & m} function bit_rol(d, _) {return d << _ | d >>> 32 - _}
	</script>
</body>

</html>

返回列表 上一筆 下一筆