1、字符编码问题解决方案

原理:过滤器技术拦截所有的controll的请求、在controll请求中使用了动态代理的设计模式监听了HttpServletRequest这个接口中getParameter方法的执行、在getParameter执行的时候、我们首先去获取这个数据、再通过判断当前的请求是GET还是POST、如果是GET那么先使用IOS-8859-1进行转码 然后使用UTF-8从新进行编码、如果是POST那么直接使用request.setCharacterEncoding(“UTF-8”)来进行处理

1.1、字符编码处理的实现

      public class CharacterFilter implements Filter{
@Override
public void init(FilterConfig arg0) throws ServletException {
}
    /**
     * 拦截的这个方法
     */
@Override
public void doFilter(ServletRequest request, ServletResponse response,
final FilterChain chain) throws IOException, ServletException {
    final HttpServletRequest req=(HttpServletRequest) request;
    final HttpServletResponse resp=(HttpServletResponse) response;
    //第一步:将返回数据的编码问题给处理了
    resp.setContentType("text/html;charset=utf-8");
    //POST的解决方案
    req.setCharacterEncoding("UTF-8");
    //第二步:监听httpServletRequest中 getParameter方法的执行
    HttpServletRequest req1= (HttpServletRequest) Proxy.newProxyInstance(HttpServletRequest.class.getClassLoader(),
     new Class[]{HttpServletRequest.class},
     new InvocationHandler() {
@Override
public Object invoke(Object proxy, Method method, Object[] args)
throws Throwable {
   //监听当前执行的方法是不是 getParameter
   String methodName=method.getName();
   if("getParameter".equals(methodName)){ //说明执行的是getParameter
  //判断当前执行的是POST呢?还是GET呢?
  String reqName=req.getMethod();
  //通过key获取这个值
  String val= (String) method.invoke(req, args);
  if("GET".equalsIgnoreCase(reqName)){ //说明是GET方法
  //执行这个方法获取这个值
  val=new String(val.getBytes("ISO-8859-1"),"UTF-8");
  }else if("POST".equalsIgnoreCase(reqName)){ //说明是POST方法
  }
  //返回这个方法执行的结果
  return val;
   }else{
  return  method.invoke(req, args);
   }
   }
});
   //最终要进行放行
   chain.doFilter(req1, resp);
}
@Override
public void destroy() {
}
}

2、字符和谐的问题

明白一个问题:什么是字符和谐:类似于博客网站上行 比如你骂人了一句话这句话并不会直接显示出来、而是显示成****等这种现象就称为字符的和谐

要实现字符和谐首先要解决编码问题(上面已经解决了)

在过滤器中设置脏数据

    //需要和谐的脏数据
private String[] dirtyData={"MMD","NND","杀人","CTM"};

在处理完字符编码问题的时候进行和谐(在处理完编码之后进行调用)

     protected String handleDirtyData(String val) {
for (int i = 0; i < dirtyData.length; i  ) {
if(val.contains(dirtyData[i])){
val=val.replaceAll(dirtyData[i],"***");
}
}
return val;
}

3、BeanUtils组件的使用

Beanutils组件是啥?

 Beanutils不是一个框架、就相当于是一个帮助类、这个帮助类的作用就是专门用来操作我们java Bean

BeanUtils组件能干啥?

 能够将一个实体的值赋值给另外一个实体、也可以将map类型的值赋值给实体、也可以将实体进行拷贝 

BeanUtils组件的使用?

导入beanUtils的包

使用BeanUtils组件的API

public void testbeanUtils() throws Exception {
User user=new User(1,"小波波","123");
//使用BeanUtils来操作这个是实体
//API:表示的是给那个对象的那个属性设置什么值
//BeanUtils.setProperty(user,"uName","小波波");
//BeanUtils.copyProperty(user,"uPwd","123");
//API:拷贝一个实体 返回值就是copy生成的新的实体
//User user2=(User) BeanUtils.cloneBean(user);
User user2=new User();
//把一个实体里面的属性copy给另外一个实体的属性
//BeanUtils.copyProperties(user2, user);
//将实体转换成map
//Map<Object,Object> maps=BeanUtils.describe(user);
//获取实体的属性值 并转换成String类型的数组
//String[] strVal=BeanUtils.getArrayProperty(user,"uName");
//将Map中的数据直接赋值给JAVA的对象
Map<String,Object> maps=new HashMap<String, Object>();
maps.put("uId",123);
maps.put("uName","小波波");
maps.put("uPwd","110");
//将map中的数据直接赋值给JAVA对象
BeanUtils.populate(user2, maps);
System.out.println(user2);
}

4、Servlet请求参数的自动封装

public static<T> T getObject(HttpServletRequest request,Class clazz) throws Exception{
//反射得到这个数据类型
T t=(T) clazz.newInstance();
//使用beanUtils组件来设置这个值
BeanUtils.populate(t,request.getParameterMap());
return t;
 }

5、源数据使用

源数据分类:数据库的源数据 、请求参数的元数据、结果集的元数据  

数据库的元数据:能够获取当前访问数据库的一些信息(数据库的名字、连接的URL、连接的用户名、数据库的版本信息)

请求参数的元数据:能够精确的知道当前的SQL语句中有多少个占位符

结果集元数据:就能清楚的知道当前访问的这个数据库的列名是什么

5.1、数据库的元数据的使用

     public void testDatabaseMetaData() throws Exception {
//第一步:加载驱动
Class.forName("com.mysql.jdbc.Driver");
//第二步:创建连接
Connection conn= DriverManager.getConnection(URL, USER, PASSWORD);
//获取数据库的元数据
DatabaseMetaData data=conn.getMetaData();
//获取数据库的相关信息
System.out.println("数据库的名字:" data.getDatabaseProductName());
System.out.println("数据库的版本:" data.getDatabaseProductVersion());
System.out.println("数据库的URL:" data.getURL());
System.out.println("访问的用户名:" data.getUserName());
System.out.println("---------------------------------------");
//第三步:创建操作数据库的对象
PreparedStatement state=conn.prepareStatement("select * from msgstateinfo");
//第四步:操作
ResultSet set=state.executeQuery();
//遍历....
while (set.next()) {
String str=set.getString("msgstate");
System.out.println("获取到的数据是:" str);
}
conn.close();
}

5.2、请求参数的元数据

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;public void testRequestParameMetaData() throws Exception {
//第一步:加载驱动
Class.forName("com.mysql.jdbc.Driver");
//第二步:创建连接
Connection conn= DriverManager.getConnection(URL, USER, PASSWORD);
System.out.println("---------------------------------------");
//第三步:创建操作数据库的对象
PreparedStatement state=conn.prepareStatement("select * from msgstateinfo where id &lt; ? and msgobj = ? and aa=?");
//第四步:玩下请求参数的元数据
ParameterMetaData data=state.getParameterMetaData();
//现在你就可以知道当前的SQL语句中有多少个占位符了
System.out.println("占位符的个数:" data.getParameterCount());
conn.close();
}

5.3、结果集元数据

    public void testResultSetMetaData() throws Exception {
//第一步:加载驱动
Class.forName("com.mysql.jdbc.Driver");
//第二步:创建连接
Connection conn= DriverManager.getConnection(URL, USER, PASSWORD);
System.out.println("---------------------------------------");
//第三步:创建操作数据库的对象
PreparedStatement state=conn.prepareStatement("select * from t_user");
ResultSet set=state.executeQuery();
//下面就可以获取结果集的元数据了
ResultSetMetaData resultSetMetaData=set.getMetaData();
while (set.next()) {   //相当于是遍历的是行
//我们还可以遍历列
int columnNum=resultSetMetaData.getColumnCount();
//通过列的下标来知道列的名字
for (int i = 0; i < columnNum; i  ) {
//通过列的下标来找到列的名字
String columnName=resultSetMetaData.getColumnName(i 1);
//知道了列的名字也就能找到这个列的值了
Object val=set.getObject(columnName);
System.out.println(val);
}
}
conn.close();
} 

5.4、封装一个通用的JDBC的增删改的方法

    public void update(String sql, Object... parames) throws Exception {
// 获取连接
Connection conn = getConnection();
// 第二步:获取操作数据库的对象
PreparedStatement state = conn.prepareStatement(sql);
// 第三步:将传递过来的参数直接赋值给占位符
// 获取占位符的个数
ParameterMetaData parameterMetaData = state.getParameterMetaData();
// 获取占位符的个数
int num = parameterMetaData.getParameterCount();
if (parames.length < num) {
throw new RuntimeException("参数不对应没法玩....");
}
// 说明参数是对的
for (int i = 0; i < num; i  ) {
// 设置参数了
state.setObject(i   1, parames[i]);
}
// 执行这个SQL语句
state.executeUpdate();
close();
}

5.5、封装一个根据条件查询返回集合的方法

public <T> List<T> findAll(String sql, Class<T> clazz,Object...parames) throws Exception {
//确定返回的这个容器
        List<T> lists=new ArrayList<T>();
// 获取连接
Connection conn = getConnection();
// 第二步:获取操作数据库的对象
PreparedStatement state = conn.prepareStatement(sql);
// 第三步:将传递过来的参数直接赋值给占位符
// 获取占位符的个数
ParameterMetaData parameterMetaData = state.getParameterMetaData();
// 获取占位符的个数
int num = parameterMetaData.getParameterCount();
if (parames.length < num) {
throw new RuntimeException("参数不对应没法玩....");
}
//判断:假设这个SQL语句根本就没有占位符呢?
if(num!=0){   //说明有占位符
// 说明参数是对的
for (int i = 0; i < num; i  ) {
// 设置参数了
state.setObject(i   1, parames[i]);
}
}
// 执行这个SQL语句
ResultSet set=state.executeQuery();
//下面移动游标遍历这个行
//获取这个列的数量
ResultSetMetaData metadata=set.getMetaData();
//可以获取这个列的数量
int columnCount=metadata.getColumnCount();
while (set.next()) {
T t=clazz.newInstance();
//遍历每一个列
for (int i = 0; i <columnCount; i  ) {
//获取每一个列的列名
String columnName=metadata.getColumnName(i 1);
//获取这个列的值
Object columnVal= set.getObject(columnName);
//把上面的属性和值 放到这个JAVA对象中去
BeanUtils.copyProperty(t, columnName, columnVal);
}
//将t放到List集合中去
lists.add(t);
}
close();
return lists;
}
``` 

以上就是字符编码的处理和BeanUtils组件的使用的详细内容,更多关于字符编码处理BeanUtils组件的资料请关注Devmax其它相关文章!

字符编码的处理和BeanUtils组件使用详解的更多相关文章

  1. ios – NSLocalizedString有时会加载字符串,而不是总是

    解决方法如果您的localisable文件中有任何额外的分号,它会构建但无法进行本地化.

  2. ios – NSString cString已被弃用.什么是替代品?

    我有另一个新手问题.我写了一段代码,将Nsstring转换为NSMutableData,以模拟一个webService结果.但事实证明,cString已被弃用.你可以帮我更换吗?这是我的代码解决方法>从字符串获取原始字节.>获取UTF8编码中这些字节的长度.>使用dataWithBytes:length:方法创建NSData对象.

  3. Swift字符unicode编码

    1、字符在C#Object语言中,字符放在单引号(')之间,但是在swift语言中,必须把字符放在双引号之间;(1)unicode编码unicode编码可以有单字节编码,双字节编码和四字节编码,它们的表现形式是"\u{n}",其中n为1到8个十六进制字符letandSign1:Character="&"letandSign2="\u{26}"letlamda1:Character=""letlam

  4. Swift语法基础:15 - Swift的Unicode使用以及标量

    接续接着说,Unicode是文本编码和表示的国际标准。它使您可以用标准格式表示来自任意语言几乎所有的字符,并能够对文本文件或网页这样的外部资源中的字符进行读写操作。Swift的字符串和字符类型是完全兼容Unicode的,它支持如下所述的一系列不同的Unicode编码。一个unicode标量是字符或者修饰符的唯一21位数(和名称),例如U+0061表示小写的拉丁字母A(“a”),U+1F425表示正面站立的鸡宝宝(“

  5. swift基础教程——字符和字符串

    9、字符串比较Swift提供三种方法比较字符串的值:字符串相等,前缀相等,和后缀相等字符串相等当两个字符串的包含完全相同的字符时,他们被判断为相等。

  6. [Swift]NSString、NSData、Base64互转

    ####Nsstring、NSData互转########Base64互转####

  7. Swift3.0语言教程删除字符与处理字符编码

    Swift3.0语言教程删除字符与处理字符编码Swift3.0语言教程删除字符Swift3.0语言教程删除字符与处理字符编码,在字符串中,如果开发者有不需要使用的字符,就可以将这些字符删除。importFoundationvara=Nsstringprintvarb:CharacterSet=NSCharacterSet.whitespacesAndNewlinesasCharacterSetprint//去除空格和回车运行结果如下:删除前:Hello删除后:HelloSwift3.0语言教程处理字符编码

  8. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

  9. Android ListView UI组件使用说明

    这篇文章主要介绍了Android ListView UI组件使用说明,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

  10. Flutter 首页必用组件NestedScrollView的示例详解

    今天介绍的组件是NestedScrollView,大部分的App首页都会用到这个组件。对Flutter 首页必用组件NestedScrollView的相关知识感兴趣的一起看看吧

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部