对xml文件头内容的理解xmlns xmlns:xsi xsi:schemaLocation

对xml文件头内容的理解xmlns xmlns:xsi xsi:schemaLocation

XML文件的结构一般如下

<?xml version="1.0" encoding="UTF-8"?>  
<beans  
  
xmlns="http://www.springframework.org/schema/beans"  
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
xmlns:context="http://www.springframework.org/schema/context"  
xsi:schemaLocation="  
http://www.springframework.org/schema/beans         
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
http://www.springframework.org/schema/context            
http://www.springframework.org/schema/context/spring-context-3.0.xsd">  
  
<bean id="helloWorld" class="main.java.com.sommer.learn.HelloWorldImpl"></bean>  
  
</beans>  


上面代码的<bean id=”helloWorld ”  class=” main.java.com.sommer.learn.HelloWorldImpl”> </bean>,其中
helloWorld
表示bean的标识,
main.java.com.sommer.learn.HelloWorldImpl
表示bean的类。这只是bean的一种最简单的配置。


beans —— xml文件的根节点。


xmlns ——是XML NameSpace的缩写,因为XML文件的标签名称都是自定义的,自己写的和其他人定义的标签很有可能会重复命名,而功能却不一样,所以需要加上一个namespace来区分这个xml文件和其他的xml文件,类似于java中的package。

xmlns是XML Namespace 的缩写,这里表示spring 命名空间。Spring在Classpath中查找所有的 spring.handlers 并解析xml配置的命名空间与对应的处理类。命名空间的这些项目不是固定的,可从 http://www.springframework.org/schema/ 根据需求选择。

这里我们先不讨论它,主要看<bean> </bean>的组成结构,因为它表示如何从IoC容器中获取对象(bean)并完成我们所需要的功能。


xmlns:xsi ——是指xml文件遵守xml规范,xsi全名:xml schema instance,是指具体用到的schema资源文件里定义的元素所准守的规范。即/spring-beans-2.0.xsd这个文件里定义的元素遵守什么标准。

xsi:schemaLocation——是指,本文档里的xml元素所遵守的规范,schemaLocation 属性用来引用(schema)模式文档,解析器可以在需要的情况下使用这个文档对 XML 实例文档进行校验。它的值(URI)是成对出现的,第一个值表示命名空间,第二个值则表示描述该命名空间的模式文档的具体位置,两个值之间以空格分隔。


bean的配置项具体如下:

全限定类名(class:用于定义Bean的实现类;

Bean行为:这些定义了Bean在容器中的行为;包括作用域(单例、原型创建)、是否惰性初始化及生命周期等;

Bean创建方式:说明是通过构造器还是工厂方法创建

Bean之间关系:即对其他bean的引用,也就是依赖关系定义,这些引用bean也可以称之为同事bean依赖bean,也就是依赖注入。

bean的命名

1.不指定id,只配置必须的全限定类名,由IoC容器为其生成一个标识,程序必须通过“getBean(Class<T> requiredType)”获取Bean

<bean class=”main.java.com.sommer.learn.HelloWorldImpl”></bean>

获取bean的程序

ApplicationContext apc = new ClassPathXmlApplicationContext("springXML/HelloWorld.xml");    
HelloWorld hello = apc.getBean(HelloWorld.class);    
System.out.println(hello.sayHi());   

2. 指定id,必须在Ioc容器中唯一;

<bean id=”helloWorld” class=”main.java.com.sommer.learn.HelloWorldImpl”></bean>

获取bean的程序

ApplicationContext apc = new ClassPathXmlApplicationContext("springXML/HelloWorld.xml");    
HelloWorld hello = apc.getBean("helloWorld",HelloWorld.class);    
System.out.println(hello.sayHi());  

3. 指定name,必须在Ioc容器中唯一

<bean name=”helloWorld” class=”main.java.com.sommer.learn.HelloWorldImpl”></bean>

获取bean的程序

ApplicationContext apc = new ClassPathXmlApplicationContext("springXML/HelloWorld.xml");    
HelloWorld hello = apc.getBean("helloWorld",HelloWorld.class);    
System.out.println(hello.sayHi()); 

4. 指定别名alias(一个bean可以有多个)

<bean name=”helloWorld”  alias=”alias1″  class=”main.java.com.sommer.learn.HelloWorldImpl”></bean>


获取bean的程序

ApplicationContext apc = new ClassPathXmlApplicationContext("springXML/HelloWorld.xml");    
HelloWorld hello = apc.getBean("alias1",HelloWorld.class);  //这里当然也可以根据name获得  
System.out.println(hello.sayHi());   

如果同时指定了idnameid就是标识符,而name就是别名,必须在Ioc容器中唯一;

如果指定多个name,第一个被用作标识符,其他的是别名,所有标识符也必须在Ioc容器中唯一;

注:nameid都作为“标识符”,那为什么还要同时存在呢?这是因为当使用基于XML的配置元数据时,在XMLid是一个真正的XML id属性,因此可以利用XML解析器来验证引用的这个id是否存在,从而更早的发现是否引用了一个不存在的bean,而使用name,则可能要在真正使用bean时才能发现引用一个不存在的bean

文章转自:http://blog.csdn.net/shymi1991/article/details/48106015

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/106272.html原文链接:https://javaforall.net

(0)
上一篇 2021年7月19日 上午11:00
下一篇 2021年7月19日 下午12:00


相关推荐

  • 单点登录sso原理及代码实现

    单点登录sso原理及代码实现什么是单点登录一个账户在多个系统上实现单一用户的登录为什么用单点登录单点登录可以做到在不记录用户密码的情况下 实现不同系统之间的资源共享 自动登录不安全 单点登录 一处登录 处处都可用 不用做多余的登录操作引用一个很经典的案例比如现在有 OA 系统 门户系统 人力资源管理系统 档案管理系统 生产管理系统 xx 系统等 这么多个系统在一个公司里面 如果一个用户需要使用这么多个系统

    2026年3月17日
    2
  • 粒子群算法matlab代码(注释很详细哦,图像也美美哒,任意维度)[通俗易懂]

    粒子群算法matlab代码(注释很详细哦,图像也美美哒,任意维度)[通俗易懂]整个程序分为5个脚本pso1_mian.m:主程序,在此脚本内设置参数。pso1_im.m:画出函数图像(仅1维和2维)pso1_in.m:初始化pso1_in2.m:迭代寻优并输出结果另外还有一个目标函数,单独为一个脚本。推荐的测试函数—>这里先上运行结果图下面是源码1.pso1_mian.m这里的目标函数用函数句柄的形式调用(第15行)%%粒子群算法%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%pso1_im

    2022年5月1日
    77
  • TCP/IP数据包结构具体解释

    TCP/IP数据包结构具体解释

    2021年11月16日
    55
  • springboot整合shiro实现权限控制

    springboot整合shiro实现权限控制ApacheShiro是一个强大且易用的Java安全框架,执行身份验证、授权、密码学和会话管理。使用Shiro的易于理解的API,您可以快速、轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序。上个月写了一个在线教育的项目用到了shiro权限控制,这几天又复盘了一下,对其进行了深入探究,来总结一下。下面所总结的有关shiro的代码已经传到我的github上,可以访问下面的……

    2025年8月22日
    5
  • Windows11 Copilot助手开启教程(免费GPT-4)

    Windows11 Copilot助手开启教程(免费GPT-4)

    2026年3月15日
    2
  • 麦克风阵列声源定位程序_麦克风阵列怎么设置

    麦克风阵列声源定位程序_麦克风阵列怎么设置麦克风阵列声源定位利用麦克风阵列可以实现声源到达方向估计(direction-of-arrival(DOA)estimation),DOA估计的其中一种方法是计算到达不同阵元间的时间差,这里主要介绍经典的GCC-PHAT方法背景简单说明问题背景,信号模型如下图,远场平面波,二元阵列要计算得到θθ\theta,其实就是要求两个阵元接收到的信号时间差,现在问题变成到达时…

    2026年2月19日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号