Commit 3dbcbfe8 authored by 周宏民's avatar 周宏民

pref: 登录验证码改为后端较验

parent 5e688ed5
...@@ -15,6 +15,7 @@ instanceRequest.transformRequestURL = function(url) { ...@@ -15,6 +15,7 @@ instanceRequest.transformRequestURL = function(url) {
'/PandaOMS/OMS/WebSite/GetConfig', '/PandaOMS/OMS/WebSite/GetConfig',
'/PandaOMS/OMS/CheckFreeLogin', '/PandaOMS/OMS/CheckFreeLogin',
'/PandaCore/GCK/BussinessAuth/HDAuthLogin', '/PandaCore/GCK/BussinessAuth/HDAuthLogin',
'/PandaCore/Identity/GetAliyunSMSVerificationCode',
]; ];
if (excludeURL.includes(url)) { if (excludeURL.includes(url)) {
return url.replace(/PandaCore\/GateWay\//, ''); return url.replace(/PandaCore\/GateWay\//, '');
......
...@@ -18,7 +18,9 @@ export const API = { ...@@ -18,7 +18,9 @@ export const API = {
GET_CITY: process.env.NODE_ENV !== 'production' ? '/cityjson?ie=utf-8' : 'https://pv.sohu.com', GET_CITY: process.env.NODE_ENV !== 'production' ? '/cityjson?ie=utf-8' : 'https://pv.sohu.com',
GET_ALL_GROUPS_INFO_FORUSER: '/PandaCore/GCK/CloudPlat/GetAllGroupsInfoForUser', GET_ALL_GROUPS_INFO_FORUSER: '/PandaCore/GCK/CloudPlat/GetAllGroupsInfoForUser',
GET_WEATHER: '/CityInterface/rest/services/CountyProduct.svc/GetWeather', GET_WEATHER: '/CityInterface/rest/services/CountyProduct.svc/GetWeather',
SEND_MESSAGE_CODE: 'CityInterface/rest/services/portal.svc/SendMessVerificationCode', SEND_MESSAGE_CODE: 'CityInterface/rest/services/portal.svc/SendMessVerificationCode', // 获取验证码 前端校验
GetAliyunSMSVerificationCodeHasWay: '/PandaCore/Identity/GetAliyunSMSVerificationCode', // 获取验证码 走网关
GetAliyunSMSVerificationCode: 'PandaCore/GCK/BussinessAuth/GetAliyunSMSVerificationCode', // 获取验证码 不走网关
CHANGE_PASSWORD: 'cityinterface/rest/services.svc/changepassword', CHANGE_PASSWORD: 'cityinterface/rest/services.svc/changepassword',
CHANGE_PASSWORD_SAFE: '/PandaOMS/OMS/UserCenter/UpdateUserPassword', CHANGE_PASSWORD_SAFE: '/PandaOMS/OMS/UserCenter/UpdateUserPassword',
HD_AUTH_LOGIN: '/PandaCore/GCK/BussinessAuth/HDAuthLogin', HD_AUTH_LOGIN: '/PandaCore/GCK/BussinessAuth/HDAuthLogin',
...@@ -177,6 +179,16 @@ const services = { ...@@ -177,6 +179,16 @@ const services = {
method: constants.REQUEST_METHOD_GET, method: constants.REQUEST_METHOD_GET,
type: constants.REQUEST_HTTP, type: constants.REQUEST_HTTP,
}, },
GetAliyunSMSVerificationCodeHasWay: {
url: API.GetAliyunSMSVerificationCodeHasWay,
method: constants.REQUEST_METHOD_GET,
type: constants.REQUEST_HTTP,
},
GetAliyunSMSVerificationCode: {
url: API.GetAliyunSMSVerificationCode,
method: constants.REQUEST_METHOD_GET,
type: constants.REQUEST_HTTP,
},
updateAvatar: { updateAvatar: {
url: API.UPDATE_AVATAR, url: API.UPDATE_AVATAR,
method: constants.REQUEST_METHOD_GET, method: constants.REQUEST_METHOD_GET,
......
...@@ -139,8 +139,10 @@ const LoginItem = props => { ...@@ -139,8 +139,10 @@ const LoginItem = props => {
const onGetCaptcha = useCallback(mobile => { const onGetCaptcha = useCallback(mobile => {
// eslint-disable-next-line no-undef // eslint-disable-next-line no-undef
if (window.globalConfig?.hasGateWay) {
// 开户网关
appService appService
.sendMessVerificationCode({ .GetAliyunSMSVerificationCodeHasWay({
phoneNumber: mobile, phoneNumber: mobile,
ignoreSite: true, ignoreSite: true,
cacheBust: true, cacheBust: true,
...@@ -154,6 +156,24 @@ const LoginItem = props => { ...@@ -154,6 +156,24 @@ const LoginItem = props => {
.catch(error => { .catch(error => {
message.error(intl.formatMessage({ id: 'pages.login.phoneLogin.errorCodeMessage' })); message.error(intl.formatMessage({ id: 'pages.login.phoneLogin.errorCodeMessage' }));
}); });
} else {
// 不开网关
appService
.GetAliyunSMSVerificationCode({
phoneNumber: mobile,
ignoreSite: true,
cacheBust: true,
})
.then(res => {
if (res) {
setExt(res.ext);
setTiming(true);
}
})
.catch(error => {
message.error(intl.formatMessage({ id: 'pages.login.phoneLogin.errorCodeMessage' }));
});
}
}, []); }, []);
useEffect(() => { useEffect(() => {
...@@ -183,18 +203,17 @@ const LoginItem = props => { ...@@ -183,18 +203,17 @@ const LoginItem = props => {
if (type === 'Captcha') { if (type === 'Captcha') {
const inputProps = omit(otherProps, ['onGetCaptcha', 'countDown']); const inputProps = omit(otherProps, ['onGetCaptcha', 'countDown']);
const equalsValidate = (rule, value) => { // const equalsValidate = (rule, value) => {
if (value === ext || value === '8888') { // if (value === ext || value === '8888') {
return Promise.resolve(); // return Promise.resolve();
} // }
// eslint-disable-next-line prefer-promise-reject-errors // return Promise.reject(intl.formatMessage({ id: 'pages.login.phoneLogin.errorMessage' }));
return Promise.reject(intl.formatMessage({ id: 'pages.login.phoneLogin.errorMessage' })); // };
};
// eslint-disable-next-line no-shadow // eslint-disable-next-line no-shadow
const rulesArr = [...rules]; const rulesArr = [...rules];
rulesArr.push({ // rulesArr.push({
validator: equalsValidate, // validator: equalsValidate,
}); // });
delete options.rules; delete options.rules;
return ( return (
......
...@@ -1375,7 +1375,7 @@ class Login { ...@@ -1375,7 +1375,7 @@ class Login {
} }
} }
login(usr, pwd, userPhone, isRememberPWD, mode = SERVICE_APP_LOGIN_MODE.password) { login(usr, pwd, userPhone, isRememberPWD, mode = SERVICE_APP_LOGIN_MODE.password, captcha) {
this.globalConfig = getGlobalConfig(); this.globalConfig = getGlobalConfig();
const self = this; const self = this;
if (window.globalConfig && window.globalConfig.hasGateWay) { if (window.globalConfig && window.globalConfig.hasGateWay) {
...@@ -1391,6 +1391,7 @@ class Login { ...@@ -1391,6 +1391,7 @@ class Login {
: '', : '',
type: mode, type: mode,
generateType: params.getParams('generateType') || '', generateType: params.getParams('generateType') || '',
vcode: captcha
}) })
.then(res => { .then(res => {
if (res.code === 0) { if (res.code === 0) {
...@@ -1442,6 +1443,8 @@ class Login { ...@@ -1442,6 +1443,8 @@ class Login {
ignoreSite: true, ignoreSite: true,
loginName: usr, loginName: usr,
generateType: params.getParams('generateType') || '', generateType: params.getParams('generateType') || '',
vcode: captcha,
}) })
.then(response => { .then(response => {
if (response?.msg === '密码过期') { if (response?.msg === '密码过期') {
...@@ -1633,7 +1636,7 @@ class Login { ...@@ -1633,7 +1636,7 @@ class Login {
} }
phoneLoginFormHandler(userPhone, captcha) { phoneLoginFormHandler(userPhone, captcha) {
this.login('', '', userPhone, '', SERVICE_APP_LOGIN_MODE.phone); this.login('', '', userPhone, '', SERVICE_APP_LOGIN_MODE.phone, captcha);
} }
slideVerify(ref, onSuccess, onFail, onRefresh) { slideVerify(ref, onSuccess, onFail, onRefresh) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment