当前位置: 首页 > 编程日记 > 正文

后台接口向数据库录入汉字时乱码以及自动过滤文字经验总结

本人第一次写博客,而且是一个菜鸟,如果有什么不完善的地方请前辈们多多指教。

2017-06-01 21:56:05

因为公司功能的需求,需要写一个溯源信息的接口,下面的代码是前台的一个用户评论的界面。所谓溯源就是追溯源头,有点类似于淘宝的物流。通过溯源信息可以查询到商品的产地、质量、商标等等一系列跟产品有关的信息。

productid:溯源产品的对应的编号,由前一个页面自动传递过来,通过这个属性将客户评论的内容与溯源产品相绑定。

username:评论者的名字。

telephone:评论者的联系方式。

rating:评论的等级,就是我们订餐时给商家评论是几颗星一样。星星的标志由前台来处理,这里只是获取从前台传递过来的值。

commentcontent:评论的内容,要求不能显示脏话、骂人话等不雅的词语,如果在评论的内容中存在这样的语言,代码将自动将其过滤掉替换为"*",并存入数据库中。

下面是具体的实现接口。

  1 public void addCommentMessage(HttpServletRequest request,
  2             HttpServletResponse response) throws UnsupportedEncodingException {
  3         JSONObject jsonObject = new JSONObject();
  4         // 敏感词汇集合
  5         String[] discuss = { "孙子", "草", "你妈", "儿子", "爸爸", "傻逼", "sb", "尼玛",
  6                 "你大爷", "混蛋", "滚", "靠", "完犊子" };
  7         String productid = request.getParamter("productid");
  8 
  9     // 修改乱码格式;这个主要是针对中文汉字来说的,这样处理在前台输入的中文汉字将不会以乱码形式存放在数据库中了。下面的代码同样的道理
 10         productid = new String(productid.getBytes("ISO-8859-1"), "utf-8");
 11 
 12     //从前台获取客户评论填写的名字
 13         String username = request.getParameter("username");
 14 
 15    //修改乱码格式
 16         username = new String(username.getBytes("ISO-8859-1"), "utf-8");
 17 
 18     //从前台获取客户评论填写的联系方式
 19         String telephone = request.getParameter("telephone");
 20 
 21     //修改乱码格式
 22         telephone = new String(telephone.getBytes("ISO-8859-1"), "utf-8");
 23 
 24     //从前台获取客户评论填写的评价等级
 25         String rating = request.getParameter("rating");
 26 
 27     //修改乱码格式
 28         rating = new String(rating.getBytes("ISO-8859-1"), "utf-8");
 29 
 30      //从前台获取客户评论填写的评论内容
 31         String commentcontent = request.getParameter("commentcontent");
 32 
 33     //修改乱码格式
 34         commentcontent = new String(commentcontent.getBytes("ISO-8859-1"),"utf-8");
 35         request.setCharacterEncoding("utf-8");
 36         try {
 37 
 38     //CommentEntity为评论的实体类,在这里直接引用的。向数据库中射值得set方法就在其中
 39             CommentEntity commentEntity = new CommentEntity();
 40 
 41     //判断传过来的productid是否为空字符串或null或"null"
 42             if (!productid.equals("") && !productid.equals(null)
 43                     && !productid.equals("null")) {
 44 
 45       //通过commentEntity实体类的set方法将信息存入到数据库中
 46                 commentEntity.setProductid(productid);
 47             }
 48             if (!username.equals("") && !username.equals(null)
 49                     && !username.equals("null")) {
 50                 commentEntity.setUsername(username);
 51             }
 52             if (!telephone.equals("") && !telephone.equals(null)
 53                     && !telephone.equals("null")) {
 54                 commentEntity.setTelephone(Integer.valueOf(telephone));
 55             }
 56             if (!rating.equals("") && !rating.equals(null)
 57                     && !rating.equals("null")) {
 58                 commentEntity.setRating(rating);
 59             }
 60             if (!commentcontent.equals("") && !commentcontent.equals(null)
 61                     && !commentcontent.equals("null")) {
 62                 // 判断评论信息是否包含敏感词汇,如果包含则将敏感部分以*的形式录入数据库
 63                 for (String s : discuss) {
 64                     if (commentcontent.contains(s)){
 65                         String str = commentcontent.replaceAll(s, "***");
 66                         commentcontent=str;
 67                         commentEntity.setCommentcontent(commentcontent);
 68                     }else if (!commentcontent.contains(s)) {
 69                         commentEntity.setCommentcontent(commentcontent);
 70                     }
 71                 }
 72 
 73             }
 74             Serializable save = this.commentService.save(commentEntity);
 75             if (!save.toString().equals("")) {
 76                 // 成功,jsonObject 赋值
 77                 jsonObject.put("code", "1");
 78                 jsonObject.put("message", "添加评论成功");
 79                 jsonObject.put("data", "");
 80                 
 81             } else {
 82                 // 失败,为jsonObject 赋值
 83                 jsonObject.put("code", "0");
 84                 jsonObject.put("message", "添加评论失败");
 85                 jsonObject.put("data", "");
 86             }
 87         } catch (NumberFormatException e) {
 88             // TODO Auto-generated catch block
 89             e.printStackTrace();
 90         }
 91         try {
 92             // 把json传到页面callback + "(" + json + ")"
 93             String callback = request.getParameter("callback");
 94             String jsonp = callback + "(" + jsonObject.toString() + ")";
 95             // 输出jsonObject
 96             PrintWriter writer = response.getWriter();
 97             response.setCharacterEncoding("utf-8");
 98             response.setContentType("text/html;charset=utf-8");
 99             writer.println(jsonp);
100         } catch (Exception e) {
101             // TODO: handle exception
102         }
103     }

转载于:https://www.cnblogs.com/1925yiyi/p/6930734.html

相关文章:

PHP新手上路(六)

5.5 计数器 让我们在首页上加上一个计数器。这个例子已经被讲过多次了&#xff0c;但是还是有利于演示怎样读写文件以及创建自己的函数。counter.inc包含以下代码&#xff1a; <? /* || 一个简单的计数器 */ function get_hitcount($counter_file) { /…

如何教计算机认识手写数字(下)

本文详细介绍了如何利用C#语言编写KDTree结构加速KNN算法来处理手写字符的识别问题。本文由安晟提供。

linux下字符串处理工具二:awk( 二),awk脚本

awk脚本 awk脚本是一个可执行的文件&#xff0c;常习惯以.awk命名。 结构&#xff1a; $test.awk #!/bin/awk -f #脚本系统中awk的位置BEGIN{} #脚本主体之前&#xff0c;执行些什么。该行内的语句&#xff0c;可以只执行一次{} #脚本主体,此中的语句&am…

JavaScript正则表达式test的用法

<script LANGUAGE"javascript">function checkStr( s)...{var regu /abc/gi;var re new RegExp(regu);return re.test(s);}checkMobile(vabceeabc);</script>用途&#xff1a;检查输入的字符串是否含有abc,如果有返回true,否则返回false方法test(string…

如何利用C#开发“通讯录”小程序

本文介绍了数理系15级魏道鑫同学汇报的成果&#xff0c;利用C#开发的通讯录小程序。

Ubuntu 16.04 install NVDIA display driver

2019独角兽企业重金招聘Python工程师标准>>> 1. search and download the driver http://www.nvidia.cn/Download/ 2. vim /etc/modprobe.d/blacklist.conf append this lines to the file blacklist vga16fb blacklist nouveau blacklist rivafb blacklist rivatv …

C#Hello World

自己是做java开发的&#xff0c;但是有时候有些问题用java解决起来很不方便&#xff0c;比如调用windows系统的东西&#xff0c;所以要快速自学一下C#&#xff0c;快速解决一个问题。 下面是一个简单的控制台程序。 using System; //using 关键字的作用是导入命名空间 using Sy…

如何利用离散Hopfield神经网络进行高校科研能力评价(1)

如何利用离散Hopfield神经网络进行高校科研能力评价(1)代码部分

OpenDNS 不再向用户展示广告

OpenDNS是流行的免费域名解析服务提供商&#xff0c;它的收入一度主要来自广告&#xff0c;当用户输入的网址无法解析它会将用户重定向到广告页。在OpenDNS诞生前&#xff0c;ISP提供的域名解析是用户唯一的选择。但ISP的DNS服务称不上有多好&#xff0c;不怎么可靠。但如今&am…

winform配置文件的简单使用(转载)

1&#xff0e; 首先创建一个winform解决方案2&#xff0e; 与添加类文件相同的方法添加配置文件&#xff0c;比如&#xff1a;右击解决方案下的项目名称—>添加—>新建项—>选择 “应用程序配置文件”&#xff0c;.net默认文件名为app.config&#xff0c;点击确定 打开…

C#版及nodejs版的com端口监听程序

感受: 写监听程序的感受&#xff1a;原来有些事情并不是想象的那么难&#xff0c;难和简单就只在一个点上&#xff0c;一个点突破了&#xff0c;后面就豁然开朗了。所以有些问题&#xff0c;不能死闷&#xff0c;要先思考&#xff0c;然后查资料&#xff0c;然后问有经验的人…

C++各大有名库的介绍之C++标准库

C各大有名库的介绍之C标准库标准库中提供了C程序的基本设施。虽然C标准库随着C标准折腾了许多年&#xff0c;直到标准的出台才正式定型&#xff0c;但是在标准库的实现上却很令人欣慰得看到多种实现&#xff0c;并且已被实践证明为有工业级别强度的佳作。1、Dinkumware C Libra…

自己动手——实现 Dustjs 中间件

Dustjs是我个人比较喜欢的一个JS模版引擎&#xff0c;原因有两个&#xff0c;一是&#xff0c;同时支持客户端和服务端渲染&#xff0c;模版编译成JS后使用&#xff0c;性能好&#xff1b;二是&#xff0c;有大公司的支持&#xff0c;Linkedin有专门的Dustjs版本&#xff08;本…

如何利用离散Hopfield神经网络进行高校科研能力评价(2)

如何利用离散Hopfield神经网络进行高校科研能力评价&#xff0c;应用部分

yyyy-MM-dd HH:mm:ss和yyyy-MM-dd hh:mm:ss

做项目&#xff0c;需要24小时制式的时间&#xff0c;误用了yyyy-MM-dd hh:mm:ss&#xff0c;导致出现一个很难发现的bug&#xff0c;现记录下,方便以后查阅。 yyyy-MM-dd hh:mm:ss 12小时制 yyyy-MM-dd HH:mm:ss 24小时制

Asp.Net开发架构设计(二)

上回说到&#xff0c;我们配置了一下UnityConfig层&#xff0c;在这个层中定义了一个IContainerAccessor的接口和一个返回IUnityContainer类型的方法&#xff0c;这个方法的主要作用就是把Service层中的接口类和Business层中的接口实现类装配到UnityContainer中并返回&#xff…

Matlab与线性代数 -- 稀疏矩阵的创建

本文详细介绍了在Matlab中创建稀疏矩阵的三种方法。

uva 10491 Cows and Cars

https://vjudge.net/problem/UVA-10491 题意&#xff1a; a头牛&#xff0c;b辆车&#xff0c;每扇门后面都有一头牛或一辆车 开始选手选择一扇门 然后主持人打开c扇有牛的门&#xff08;选中的除外&#xff09; 然后选手换一扇门 问最后选手选的门后面是车的概率 开始选牛的概…

ssh免密码登录的原理

工作第一天&#xff0c;就需要登录各种服务器&#xff0c;免密码登录无疑能大大的提高工作效率。以前只知道配置&#xff0c;今天了解了下原理。 免密码登录原理 图解&#xff0c;server A免登录到server B: 1.在A上生成公钥私钥。 2.将公钥拷贝给server B&#xff0c;要重命…

mysql-cluster 安装配置

mysql-cluster免编译包下载&#xff1a;https://dev.mysql.com/downloads/file/?id469881 新版本支持只把索引和用到的数据加载到内存&#xff0c;而不是老版本的整个数据库都得加到内存中wget https://cdn.mysql.com//Downloads/MySQL-Cluster-7.5/mysql-cluster-gpl-7.5.6-l…

ExtJs学习笔记(5)_Ajax示例

ExtJs对于Ajax的使用非常简单&#xff0c;看下面的代码: 1.Html页&#xff1a; <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns"http://www.w3.o…

Matlab与线性代数 -- 稀疏矩阵的图形显示

本文详细说明了Matlab中稀疏矩阵可视化的过程。

浏览器及时感知服务端数据变化的方式

需求 在公司&#xff0c;有一个需求&#xff0c;是浏览器实时获取服务端数据变化&#xff0c;然后根据变化做相应的动作。需求场景如下&#xff1a;手机端扫描二维码&#xff0c;然后获取待取件订单列表&#xff0c;点击取件&#xff0c;进行取件&#xff0c;同时远端打印机打…

拥抱Node.js 8.0,N-API入门极简例子

本文摘录自《Nodejs学习笔记》&#xff0c;更多章节及更新&#xff0c;请访问 github主页地址。欢迎加群交流&#xff0c;群号 197339705。 N-API简介 Node.js 8.0 在2017年6月份发布&#xff0c;升级的特性中&#xff0c;包含了N-API。编写过或者使用过 node扩展的同学&#x…

什么是标记符控制的分水岭算法

本文首先指出传统分水岭算法的不足&#xff0c;然后介绍了标记符控制的分水岭算法&#xff0c;最后通过实例演示了该算法在图像分割中的应用。该微信图文由安晟提供。

.NE 后退刷新验证码

Response.Buffer true; Response.Expires -1; Response.ExpiresAbsolute DateTime.Now.AddDays(-1); Response.Expires0; Response.CacheControl "no-cache"; 转载于:https://www.cnblogs.com/lmjob/archive/2008/09/01/128096…

intellij打开工程在每个java文件上有个红色的无效符的解决办法

说明该类不是可编译文件。在project Structure中&#xff08;快捷键ctrlaltshifts&#xff09;选Modules将你带红圈的文件添加上&#xff0c;将你带红圈的文件夹设为Sources。一般是src文件夹&#xff0c;点Sources文件夹&#xff0c;然后点击OK。设置为可编译文件再去工程中看…

[zt] petshop4.0 详解之三

三、PetShop数据访问层之消息处理在进行系统设计时&#xff0c;除了对安全、事务等问题给与足够的重视外&#xff0c;性能也是一个不可避免的问题所在&#xff0c;尤其是一个B/S结构的软件系统&#xff0c;必须充分地考虑访问量、数据流量、服务器负荷的问题。解决性能的瓶颈&a…

windows下Bullet 2.82编译安装(Bullet Physics开发环境配置)

平台&#xff1a;Win7&#xff0c;VS2010 1. Bullet库的组织 下图是Bullet_User_Manual中的截图&#xff1a; 从中可见&#xff0c;Bullet的LinearMath&#xff08;线性数学模块&#xff09;&#xff0c;其上是BulletCollision&#xff08;碰撞检测模块&#xff09;&#xff0c…

Matlab与线性代数 -- 寻找矩阵的非零元素

本微信图文详细介绍了Matlab中find函数的用法。