反馈已提交

网络繁忙

与数据库中数据对比校验

  • 文档创建者:文档助手1
  • 历史版本:24
  • 最近更新:TW 于 2024-06-13
  • 1. 概述

    1.1 问题描述

    在填报模板中,希望将用户填入的数据和数据库中相关的数据进行对比,做一些自定义的校验。

    例如:用户修改密码时,先输入旧密码。如果旧密码和数据库中存储的密码一致,则允许修改,否则弹出提示。如下图所示:

    A1ABC9A3-70F4-414B-9720-F01EB3040720.GIF

    1.2 实现思路

    添加内置校验,使用公式获取数据库数据,和单元格输入值对比进行校验。

    2. 操作步骤

    2.1 模板设计

    如下图设计表样,B2 和 B3 单元格添加密码控件。

    Snag_e0cd2dd.png

    2.2 报表填报属性设置

    菜单栏点击「模板>报表填报属性」,新增「内置SQL」提交,数据库为 FRDemo,表为 userinfo,智能添加字段 username 和 userpass,值分别为参数$fine_username和 B3 单元格,勾选 username 为主键,如下图所示:

    注:参数$fine_username代表获取当前登录用户的用户名,用于修改密码。其具体应用可参考文档 权限细粒度之参数控制

    Snag_e1215aa.png

    2.3 数据校验设置

    菜单栏点击「模板>报表填报属性」,数据校验新增「内置校验」,新增一个校验项。如下图所示:

    在校验公式内输入:B2==sql("FRDemo","select * from userinfo where username='"+$fine_username+"'",3)

    在校验出错信息中输入:"输入的原始密码与数据库中的原始密码不同,不能修改!"

    注:校验公式的含义是在 userinfo 表中查询用户名对应的密码,详细公式解释参见文档 SQL函数

    Snag_1ef52ea.png

    2.4 效果预览

    使用 Anna 的账号预览模板。

    Snag_e1c08c9.png

    Anna 在 userinfo 表中的密码为 123456。

    Snag_e1ef830.png

    当输入的旧密码不是 123456 时,数据校验提示:输入的原始密码与数据库中的原始密码不同,不能修改!

    当输入的旧密码是 123456 时,数据校验提示:校验成功,后续点击提交即可将新密码提交入库。如下图所示:

    A1ABC9A3-70F4-414B-9720-F01EB3040720.GIF

    3. 模板下载

    已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\Form\密码校验.cpt

    点击下载模板:密码校验.cpt

    附件列表


    主题: 填报应用
    已经是第一篇
    已经是最后一篇
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭



    AI

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持