Greasy Fork 支持简体中文。

nti56 dev token refresh

1、自动填充验证码 2、从json数据中取值单独放一份到localStorage中

目前為 2021-06-22 提交的版本,檢視 最新版本

// ==UserScript==
// @name         nti56 dev token refresh
// @namespace    http://tampermonkey.net/
// @version      0.3.1
// @description  1、自动填充验证码 2、从json数据中取值单独放一份到localStorage中
// @author       niushuai233
// @run-at       document-start
// @match        *://*.nti56.com/*
// @match        http://localhost/*
// @require      https://unpkg.com/[email protected]/dist/ajaxhook.min.js
// @grant        none
// ==/UserScript==

(function() {
    'use strict';
    filterCodeRequest();

    function autoRefreshToken() {
        var localStorage = window.localStorage;
        var token = localStorage.getItem('pro__Access-Token');
        var imestoken = '根据key[pro__Access-Token]未找到[token]'
        if (token && token.length > 0) {
            imestoken = JSON.parse(token).value;
        }
        localStorage.setItem('imes_token', imestoken);
        console.log('imes token refresh success', imestoken);
    }

    function filterCodeRequest() {

        var code_url = '/ils/sys/getCheckCode';
        var isCodeUrl = false;
        ah.proxy({
            //请求发起前进入
            onRequest: (config, handler) => {
                var url_arr = config.url.split("?")
                console.log(url_arr, new Date().toLocaleString())
                if (code_url == url_arr[0]) {
                    isCodeUrl = true
                }
                handler.next(config);
            },
            onError: (err, handler) => {
                console.log(err.type)
                handler.next(err)
            },
            //请求成功后进入
            onResponse: (response, handler) => {
                autoRefreshToken()
                var res = response.response;
                if (isCodeUrl) {
                    res = JSON.parse(res);
                    autoFillCode(res.result.code);
                    isCodeUrl = false
                }
                handler.next(response)
            }
        });
    }

    function autoFillCode(code) {
        const usernameInput = document.querySelector('input[id=inputCode]')
        const button = document.querySelector('.login-button')

        const event = document.createEvent('HTMLEvents')
        event.initEvent('input', false, true)

        usernameInput.value = code // 修改用户名输入框的值
        usernameInput.dispatchEvent(event) // 手动触发输入框的input事件

        button.click() // 触发按钮点击事件
    }



})();