更新时间:2024-06-25 GMT+08:00
创建用户登录脚本
用户登录脚本是组装“业务用户登录”页面中,自定义登录组件调用的业务逻辑,之前创建的登录页只有前端页面,本节将创建完整的登录业务逻辑。
操作步骤
- 在“我的应用”中,单击“设备维修管理系统”,进入应用。
- 在“User”目录中,将鼠标放在“Script”上,单击界面上出现的“+”,在弹出菜单中选择“脚本”。
- 在弹窗中,选中“创建一个新脚本”,在“名称”文本框中输入“login”,单击“添加”。
- 在代码编辑器中,插入如下脚本代码。
import * as buffer from "buffer"; import * as crypto from "crypto"; import * as db from "db"; import * as context from 'context'; //定义入参结构,包括账号的用户名、密码为必填字段,验证码为非必填字段 @action.object({ type: "param" }) export class ActionInput { @action.param({ type: 'String', required: true, label: 'string' }) username: string; @action.param({ type: 'String', required: true, label: 'string' }) password: string; @action.param({ type: 'String', required: true, label: 'string' }) captcha: string; } //定义出参结构,出参包含5个参数,登录结果和用户角色 @action.object({ type: "param" }) export class ActionOutput { @action.param({ type: 'String' }) msg: string; @action.param({ type: 'String' }) username: string; @action.param({ type: 'String' }) userId: string; @action.param({ type: 'String' }) captcha: string; @action.param({ type: 'String' }) profile: string; } //使用数据对象PortalUser @useObject(['PortalUser']) @action.object({ type: "method" }) export class Login { //定义接口类,接口的入参为ActionInput,出参为ActionOutput @action.method({ input: 'ActionInput', output: 'ActionOutput' }) public login(input: ActionInput): ActionOutput { let out = new ActionOutput(); //新建出参ActionOutput类型的实例,作为返回值 let error = new Error(); //新建错误类型的实例,用于在发生错误时保存错误信息 try { out.captcha = input.captcha; let s = db.object('PortalUser'); let condition = { "conjunction": "AND", "conditions": [{ "field": "usrName", "operator": "eq", "value": input.username }] }; let user = s.queryByCondition(condition); if (user && user.length == 1) { if (validate(user[0].passwordSalt, user[0].userPassword, input.password)) { out.msg = "登录成功!"; out.username = user[0].usrName; out.userId = user[0].id; out.profile = user[0].userType; } else { out.msg = "密码错误!"; } } else { out.msg = "用户不存在!"; } } catch (error) { console.error(error.name, error.message); context.setError(error.name, error.message); out.msg = error.message; } return out; } } function _salt(password: string, saltBuf: buffer.Buffer, encoding: buffer.Encoding = buffer.Encoding.Base64): string { const passwordBuf = buffer.from(password) const crypt = crypto.pbkdf2(passwordBuf, saltBuf, 1000, 32, crypto.Hashs.SHA1) return crypt.toString(encoding) } function validate(salt: string, userSaltedPassword: string, password: string, encoding: buffer.Encoding = buffer.Encoding.Base64): boolean { const saltBuf = buffer.from(salt, encoding); const saltedPassword = _salt(password, saltBuf, encoding); return saltedPassword === userSaltedPassword }
- 单击编辑器上方的,保存脚本。
- 测试脚本能否正常执行。
- 单击编辑器上方的,执行脚本。
- 在界面底部输入测试数据,单击测试窗口右上角执行图标,其中“test_cs”、变量“{XXXXXXXX}”为用户注册脚本中测试数据。
{ "username": "test_cs", "password": "{XXXXXXXX}", "captcha": "" }
执行成功,会在“输出”页签返回查询结果。
{ "captcha": "", "msg": "登录成功!", "profile": "cs", "userId": "10gg0XXXXXXXXXXXXX", "username": "test_cs" }
- 测试成功,单击编辑器上方的,启动发布脚本。
父主题: 开发业务逻辑