反饋已提交

網絡繁忙

与数据库中数据对比校验

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後關閉

獲取幫助
線上支援
獲取專業技術支援,快速幫助您解決問題
工作日9:00-12:00,13:30-17:30在线
頁面反饋
針對當前網頁的建議、問題反饋
售前咨詢
業務咨詢
電話:0933-790886或 0989-092892
郵箱:taiwan@fanruan.com
頁面反饋
*問題分類
不能為空
問題描述
0/1000
不能為空

反馈已提交

网络繁忙