java中的级联什么意思(Java中shh框架的原理是怎样的啊)
这篇文章给大家聊聊关于java中的级联什么意思,以及Java中shh框架的原理是怎样的啊对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。
java中hash函数都有什么用啊
Hash,一般翻译做"散列",也有直接音译为"哈希"的,就是把任意长度的输入(又叫做预映射, pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值。这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能会散列成相同的输出,而不可能从散列值来唯一的确定输入值。
简单的说就是一种将任意长度的消息压缩到某一固定长度的消息摘要的函数。
HASH主要用于信息安全领域中加密算法,他把一些不同长度的信息转化成杂乱的128位的编码里,叫做HASH值.也可以说,hash就是找到一种数据内容和数据存放地址之间的映射关系
了解了hash基本定义,就不能不提到一些著名的hash算法,MD5和 SHA1可以说是目前应用最广泛的Hash算法,而它们都是以 MD4为基础设计的。那么他们都是什么意思呢?
这里简单说一下:
1) MD4
MD4(RFC 1320)是 MIT的 Ronald L. Rivest在 1990年设计的,MD是 Message Digest的缩写。它适用在32位字长的处理器上用高速软件实现--它是基于 32位操作数的位操作来实现的。
2) MD5
MD5(RFC 1321)是 Rivest于1991年对MD4的改进版本。它对输入仍以512位分组,其输出是4个32位字的级联,与 MD4相同。MD5比MD4来得复杂,并且速度较之要慢一点,但更安全,在抗分析和抗差分方面表现更好
3) SHA1及其他
SHA1是由NIST NSA设计为同DSA一起使用的,它对长度小于264的输入,产生长度为160bit的散列值,因此抗穷举(brute-force)性更好。SHA-1设计时基于和MD4相同原理,并且模仿了该算法。
java内省和反射的区别
经过多方面的资料搜集整理,写下了这篇文章,本文主要讲解java的反射和内省机制,希望对大家有点帮助,也希望大家提出不同的看法!
1).内省(Introspector)是 Java语言对 Bean类属性、事件的一种缺省处理方法。例如类 A中有属性 name,那我们可以通过 getName,setName来得到其值或者设置新的值。通过 getName/setName来访问 name属性,这就是默认的规则。 Java中提供了一套 API用来访问某个属性的 getter/setter方法,通过这些 API可以使你不需要了解这个规则(但你最好还是要搞清楚),这些 API存放于包 java.beans中。
2).直接通过属性的描述器java.beans.PropertyDescriptor类,来访问属性的getter/setter方法;
相关代码:
public class Point{
private Integer x;
private Integer y;
public Point(Integer x, Integer y){
super();
this.x= x;
this.y= y;
}
public Integer getX(){
return x;
}
public void setX(Integer x){
this.x= x;
}
public Integer getY(){
return y;
}
public void setY(Integer y){
this.y= y;
}
}
import java.beans.PropertyDescriptor;
import java.lang.reflect.Method;
public class Reflect{
public static void main(String[] args) throws Exception{
Point point= new Point(2, 5);
String proName="x";
getProperty(point, proName);
setProperty(point, proName);
}
private static void setProperty(Point point, String proName) throws Exception{
PropertyDescriptor proDescriptor= new PropertyDescriptor(proName, Point.class);
Method methodSetX= proDescriptor.getWriteMethod();
methodSetX.invoke(point, 8);
System.out.println(point.getX());// 8
}
private static void getProperty(Point point, String proName) throws Exception{
PropertyDescriptor proDescriptor= new PropertyDescriptor(proName, Point.class);
Method methodGetX= proDescriptor.getReadMethod();
Object objx= methodGetX.invoke(point);
System.out.println(objx);// 2
}
}
3).通过类 Introspector来获取某个对象的 BeanInfo信息,然后通过 BeanInfo来获取属性的描述器( PropertyDescriptor),通过这个属性描述器就可以获取某个属性对应的 getter/setter方法,然后我们就可以通过反射机制来调用这些方法。
相关代码:
把2中的getProperty()修改成如下形式:
private static void getProperty(Point point, String proName) throws Exception{
BeanInfo beanInfo= Introspector.getBeanInfo(point.getClass());
PropertyDescriptor[] proDescriptors= beanInfo.getPropertyDescriptors();
for(PropertyDescriptor prop: proDescriptors){
if(prop.getName().equals(proName)){
Method methodGetx= prop.getReadMethod();
System.out.println(methodGetx.invoke(point));//8
break;
}
}
}
4).我们又通常把javabean的实例对象称之为值对象(Value Object),因为这些bean中通常只有一些信息字段和存储方法,没有功能性方法。一个JavaBean类可以不当JavaBean用,而当成普通类用。JavaBean实际就是一种规范,当一个类满足这个规范,这个类就能被其它特定的类调用。一个类被当作javaBean使用时,JavaBean的属性是根据方法名推断出来的,它根本看不到java类内部的成员变量(javabean的成员变量通常都是私有private的)。
5).除了反射用到的类需要引入外,内省需要引入的类如下所示,它们都属于java.beans包中的类,自己写程序的时候也不能忘了引入相应的包或者类。
import java.beans.BeanInfo;
import java.beans.IntrospectionException;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
6).下面讲解一些开源的工具类Beanutils,需要额外下载的,commons-beanutils.jar,要使用它还必须导入commons-logging.jar包,不然会出异常;
相关代码一:
public static void main(String[] args) throws Exception{
Point point= new Point(2, 5);
String proName="x";
BeanUtils.setProperty(point, proName,"8");
System.out.println(point.getX());// 8
System.out.println(BeanUtils.getProperty(point, proName));// 8
System.out.println(BeanUtils.getProperty(point, proName).getClass().getName());// java.lang.String
BeanUtils.setProperty(point, proName, 8);
System.out.println(BeanUtils.getProperty(point, proName).getClass().getName());// java.lang.String
}
//我们看到虽然属性x的类型是Integer,但是我们设置的时候无论是Integer还是String,BeanUtils的内部都是当成String来处理的。
相关代码二:
BeanUtils支持javabean属性的级联操作;
public static void main(String[] args) throws Exception{
Point point= new Point(2, 5);//在point中加一个属性 private Date birth= new Date();并产生setter/getter方法
String proName="birth";
Date date= new Date();
date.setTime(10000);
BeanUtils.setProperty(point, proName, date);
System.out.println(BeanUtils.getProperty(point, proName));
BeanUtils.setProperty(point,"birth.time", 10000);
System.out.println(BeanUtils.getProperty(point,"birth.time"));//10000
}
//之所以可以 BeanUtils.setProperty(point,"birth.time", 10000);这样写,那是因为Date类中有getTime()和setTime()方法,即Date类中相当于有time这个属性。
相关代码三:
BeanUtils和PropertyUtils对比:
public static void main(String[] args) throws Exception{
Point point= new Point(2, 5);
String proName="x";
BeanUtils.setProperty(point, proName,"8");
System.out.println(BeanUtils.getProperty(point, proName));//8
System.out.println(BeanUtils.getProperty(point, proName).getClass().getName());//java.lang.String
// PropertyUtils.setProperty(point, proName,"8");//exception:argument type mismatch
PropertyUtils.setProperty(point, proName, 8);
System.out.println(PropertyUtils.getProperty(point, proName));//8
System.out.println(PropertyUtils.getProperty(point, proName).getClass().getName());//java.lang.Integer
}
//BeanUtils它以字符串的形式对javabean进行转换,而PropertyUtils是以原本的类型对javabean进行操作。如果类型不对,就会有argument type mismatch异常。
6).理解了相应的原理,那些现成的工具用起来就会更舒服,如Beanutils与PropertyUtils工具。这两个工具设置属性的时候一个主要区别是PropertyUtils.getPropety方法获得的属性值的类型为该属性本来的类型,而BeanUtils.getProperty则是将该属性的值转换成字符串后才返回。
Web开发框架 Struts中的 FormBean就是通过内省机制来将表单中的数据映射到类的属性上,因此要求 FormBean的每个属性要有 getter/setter方法。但也并不总是这样,什么意思呢?就是说对一个 Bean类来讲,我可以没有属性,但是只要有 getter/setter方法中的其中一个,那么 Java的内省机制就会认为存在一个属性,比如类中有方法 setMobile,那么就认为存在一个 mobile的属性。
将 Java的反射以及内省应用到程序设计中去可以大大的提供程序的智能化和可扩展性。有很多项目都是采取这两种技术来实现其核心功能,例如我们前面提到的 Struts,还有用于处理 XML文件的 Digester项目,其实应该说几乎所有的项目都或多或少的采用这两种技术。在实际应用过程中二者要相互结合方能发挥真正的智能化以及高度可扩展性。
Java中shh框架的原理是怎样的啊
java web中shh框架的原理如下:
1.典型的J2EE三层结构,分为表现层、中间层(业务逻辑层)和数据服务层。三层体系将业务规则、数据访问及合法性校验等工作放在中间层处理。客户端不直接与数据库交互,而是通过组件与中间层建立连接,再由中间层与数据库交互。
表现层是传统的JSP技术,自1999年问世以来,经过多年的发展,其广泛的应用和稳定的表现,为其作为表现层技术打下了坚实的基础。
中间层采用的是流行的Spring+Hibernate,为了将控制层与业务逻辑层分离,又细分为以下几种。
Web层,就是MVC模式里面的“C”(controller),负责控制业务逻辑层与表现层的交互,调用业务逻辑层,并将业务数据返回给表现层作组织表现,该系统的MVC框架采用Struts。
Service层(就是业务逻辑层),负责实现业务逻辑。业务逻辑层以DAO层为基础,通过对DAO组件的正面模式包装,完成系统所要求的业务逻辑。
DAO层,负责与持久化对象交互。该层封装了数据的增、删、查、改的操作。
PO,持久化对象。通过实体关系映射工具将关系型数据库的数据映射成对象,很方便地实现以面向对象方式操作数据库,该系统采用Hibernate作为ORM框架。
2.Spring的作用贯穿了整个中间层,将Web层、Service层、DAO层及PO无缝整合,其数据服务层用来存放数据。
3.一个良好的框架可以让开发人员减轻重新建立解决复杂问题方案的负担和精力;它可以被扩展以进行内部的定制化;并且有强大的用户社区来支持它。框架通常能很好的解决一个问题。然而,你的应用是分层的,可能每一个层都需要各自的框架。仅仅解决UI问题并不意味着你能够很好的将业务逻辑和持久性逻辑和UI组件很好的耦合。
OK,关于java中的级联什么意思和Java中shh框架的原理是怎样的啊的内容到此结束了,希望对大家有所帮助。