历史版本21 :与数据库中数据对比校验 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

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_e153161.png

校验的意义:B2 里面的数据必须和当前用户的密码相同,若不同则报错。

注:这个例子只是说明将单元格中的数据和数据库的数据进行匹配校验,您也可以对单元格进行其它校验设置。

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