atitit.数据验证--db数据库数据验证约束

1. 为了加强账户数据金额的安全性,需要增加验证字段。。1

2. 创建帐户1

3. 更改账户2

4. ---code3

5. --fini4

1. 为了加强账户数据金额的安全性,需要增加验证字段。。

调用::

在创建,更改金额的时候,都要更改前验证。。。

更改金额的时候,还要严重数据库里面的数据准确性

更改时的加密数据从哪里来,直接从校验器来就是了。。

new SqlCheckor().getValideVal(new_money);

作者::  ★(attilax)>>>   绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙,  EMAIL:1466519819@qq.com

转载请注明来源: http://www.cnblogs.com/attilax/

2. 创建帐户

public void createAcc(String uname, double d) {

BigDecimal money=new BigDecimal(d);

String v_vali=new SqlCheckor().getValideVal(money);

String   $sql = "insert into   ecs_users( "+

"   user_name,user_money,vali_val )values('@u@',  "+String.valueOf(d)+"" +

",'$vali$' )";

$sql= $sql.replace("@u@", uname).replace("$vali$", v_vali);

System.out.println("---"+  $sql);

sqlCkSrv.valideValCheck4newRow(money, v_vali);

int r=dbx.execSql_retInt($sql);

System.out.println("----ret int:"+String.valueOf(r));

3. 更改账户

public int addAmount(String uid, BigDecimal i) {

iniAcc(uid);

String sql = strUtil.fmt( "select * from ecs_users where user_name='$uid$'",uid);

Map row=dbx.uniqueResult2row(sql);

if(row==null)

throw new CantFindAcc("uid="+uid);

BigDecimal now=(BigDecimal) row.get("user_money");

//SqlCheckor sqlCkSrv=

if(row.get("vali_val")!=null)   //for compati  olddata no vali

sqlCkSrv.valideValCheck4oldrow(row.get("user_money"),row.get("vali_val").toString() );

BigDecimal  new_money=now.add(i);

String new_money_valinew SqlCheckor().getValideVal(new_money);

new SqlCheckor().valideValCheck4newRow(new_money, new_money_vali);

//DataLogicSales

// TODO Auto-generated method stub

/* 更新用户信息 */

String sql2 = "UPDATE   ecs_users "+

" SET user_money =$newMoney$,vali_val='$vali$'"+

" WHERE user_name = '"+uid+"' LIMIT 1";

String   $sql = sql2.replace("$newMoney$", new_money.toString()).replace("$vali$",new_money_vali);

System.out.println("---"+  $sql);

int r=dbx.execSql_retInt($sql);

if(r!=1)

throw new AccEx(" acc ex ret is:"+String.valueOf(r) +" uid:"+uid);

System.out.println("----ret int:"+String.valueOf(r));

return r;

}

}

4. ---code

public void valideValCheck4oldrowString sql,String col,String valide_col) {

//Map row=sqlSrv.executeQueryFirstRow(sql);

//String v=(String) row.get(col);

//String valid=(String) row.get(valide_col);

//if(! AesV2q421.encrypt(v, "ilovmole").equals(valid))

//

//throw new ValidValCheckEx("sql:"+sql);

}

public void valideValCheck4newRow(Object val,String valEncoded) {

if(! AesV2q421.encrypt(val.toString(), "ilovmole").equals(valEncoded))

throw new ValidValCheckEx("val.encode:"+val+"-"+valEncoded);

}

public String getValideVal(Object v)

{

return AesV2q421.encrypt(v.toString(), "ilovmole");

}

/**should str2 dec compare..cant dec2str comapre..cause to db and from db ,then num point maybe changte...but true val is not change..

attilax    2016年4月25日  下午10:24:55

* @param object

* @param object2

*/

public void valideValCheck4oldrow(Object val, String valEncoded) {

//8CBAC0UjkdSjLBFwKNB2iA==

BigDecimal money=new BigDecimal(  AesV2q421.decrypt(valEncoded, "ilovmole"));

if(money.compareTo(   (BigDecimal) val)!=0)

throw new ValidValCheckEx("val.encode:"+val+"-"+valEncoded);

5. --fini

}

atitit.数据验证--db数据库数据验证约束的更多相关文章

  1. 通过读取excel数据和mysql数据库数据做对比(二)-代码编写测试

    通过上一步,环境已搭建好了. 下面开始实战, 首先,编写链接mysql的函数conn_sql.py import pymysql def sql_conn(u,pwd,h,db): conn=pymy ...

  2. java 对excel操作 读取、写入、修改数据;导出数据库数据到excel

    ============前提加入jar包jxl.jar========================= // 从数据库导出数据到excel public List<Xskh> outPu ...

  3. 通过读取excel数据和mysql数据库数据做对比(一)-win环境准备

    要想操作excel和mysql首先需要安装python,然后是安装excel和mysql插件: 第一步安装python: 直接百度搜索,下载安装就可以了. 第二步安装excel插件: 首先到这个htt ...

  4. C#在listview控件中显示数据库数据

    一.了解listview控件的属性 view:设置为details columns:设置列 items:设置行 1.将listview的view设置为details 2.设置列属性 点击添加,添加一列 ...

  5. ajax验证表单元素规范正确与否 ajax展示加载数据库数据 ajax三级联动

    一.ajax验证表单元素规范正确与否 以用ajax来验证用户名是否被占用为例 1创建表单元素<input type="text" id="t"> 2 ...

  6. 01- ajax, 登录验证,json数据,文件上传

    1.ajax简介 1.向服务器发送请求的途径 # 向服务器发送请求的途径 1. 浏览器地址栏,默认get请求 2. form表单: get请求 post请求 3. a标签,默认get请求 4. Aja ...

  7. Oracle 数据库表中已有重复数据添加唯一键(唯一约束)

    Oracle 数据库表中已有重复数据添加唯一键(唯一约束) 问题描述 以 demo 举例,模拟真实场景. 表 TEST_TABLE 有如下字段和数据:id 是主键,code 没有设置键和索引 ID C ...

  8. 第十节:数据批注(DataAnnotationModel)和自定义验证(包括Model级别的验证)

    一. 简介 写完上一个章节MVC中的常用特性,迫不及待将该系列补全,该章节主要介绍数据批注(也叫:注解). 一听[数据批注],好高大上的名字,但仔细一看,它们其实是[System.ComponentM ...

  9. 我这么玩Web Api(二):数据验证,全局数据验证与单元测试

    目录 一.模型状态 - ModelState 二.数据注解 - Data Annotations 三.自定义数据注解 四.全局数据验证 五.单元测试   一.模型状态 - ModelState 我理解 ...

随机推荐

  1. DRA(Data Recovery Advisor)的使用

    关于DRA的官方描述: The simplest way to diagnose and repair database problems is to use the Data Recovery Ad ...

  2. Lining.js - 为CSS提供 ::nth-Line 选择器功能

    在CSS中,我们使用 ::first-line 选择器来给元素第一行内容应用样式.但目前还没有像 ::nth-line.::nth-last-line 甚至 ::last-line 这样的选择器.实际 ...

  3. 帮助你提高排版技巧的18个 PS 文字特效教程

    Photoshop 文字特效教程对于学习基础的和高级的排版思维有很大的帮助.在这篇文章中,你会发现一组最新发布的文字效果教程.这些高品质的 Photoshop 教程可以帮助你设计出惊人的2D,3D,木 ...

  4. Elasticsearch集群管理

    ES通过设置[节点的名字]和[集群的名字],就能自动的组织相同集群名字的节点加入到集群中,并使很多的技术对用户透明化. 如果用户想要管理查看集群的状态,可以通过一些REST API来实现. 其他的ES ...

  5. JVM之类加载器上篇

    首先我们先看一个示例程序: package com.tfdd.test; /** * @desc 类加载校验 * @author chenqm * @date 2016年2月2日 */ class S ...

  6. C# Winform 通过FlowLayoutPanel及自定义的编辑控件,实现快速构建C/S版的编辑表单页面

    个人理解,开发应用程序的目的,不论是B/S或是C/S结构类型,无非就是实现可供用户进行查.增.改.删,其中查询用到最多,开发设计的场景也最为复杂,包括但不限于:表格记录查询.报表查询.导出文件查询等等 ...

  7. 用Android模拟器也可以开发和测试NFC应用

    从Android2.3开始支持NFC.不过NFC应用只能在Android手机(或平板电脑)上测试和开发,而且Android手机还必须有NFC芯 片.而且如果测试NFC传输文件时至少需要两部支持NFC的 ...

  8. Android Studio快捷键每日一练(4)

    原文地址:http://www.developerphil.com/android-studio-tips-of-the-day-roundup-4/ 33.分析数据流到当前位置 苹果/Windows ...

  9. Ubuntu Server 16.04下ASP.NET Core Web Api + MySql + Dapper在 Jexus、nginx 下的简单测试

    一.环境及工具 1.服务器 VirtualBox5.1.4 安装 Ubuntu Server 16.04 amd64 MySql Ver 14.14 Distrib 5.6.21 Jexus 5.8. ...

  10. ASP.NET页面事件:顺序与回传详解

    当页面被提交请求第一个方法永远是构造函数.您可以在构造函数里面初始一些自定义属性或对象,不过这时候因为页面还没有被完全初始化所以多少会有些限制.特别地,您需要使用HttpContext对象.当前可以使 ...