Spring入门(B站狂神说Spring的笔记)

Spring(狂神说笔记)

初始spring

1.简介

  • Spring是一个开源的免费的框架(容器)
  • Spring是一个轻量级的,非入侵的框架
  • 控制反转(IOC),面向切面编程(AOP)
  • 支持事务处理,对框架整合的支持

Spring就是一个轻量级的控制反转(IOC)和面向切面编程(AOP)的框架

2.组成

img

3.扩展

  • SpringBoot
    • 一个快速开发的脚手架
    • 基于Springboot可以快速开发单个微服务
    • 约定大于配置
  • SpringCloud
    • SpringCloud是基于SpringBoot实现的

IOC的理解

可以参考前面的springboot第七节课笔记对IOC的理解

下面简单看一下spring中对IOC代码实现

1.简单例子

pojo类的编写

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Hello {
   
    private String str;
}

bean的注册

id相当于变量名,class是new的对象,property代表属性,name是具体的属性,value是属性的值,ref是已经创建好的bean的id

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="hello" class="com.hznu.ch.pojo.Hello">
        <property name="str" value="hello world"/>
    </bean>
</beans>

测试

public class MyTest {
   
    public static void main(String[] args) {
   
        ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
        Hello bean = (Hello) ctx.getBean("hello");
        System.out.println(bean);
    }
}

以上这个过程就叫控制反转

控制:谁来控制对象的创建,传统应用程序的对象是由程序本身控制创建,使用spring后,对象是由spring来创建的

反转:程序本身不创建对象,而变成被动的接收对象

IOC更是一种编程思想,由主动的编程变成被动的接收

为了更加深刻的了解IOC,我们接下来来一个更加复杂的例子

2.复杂例子

image-20201125165420463

dao层

public interface UserDao {
   
    void test();
}

public class UserDaoMysqlImpl implements UserDao{
   
    public void test() {
   
        System.out.println("mysql");
    }
}

public class UserDaoOracleImpl implements UserDao {
   
    public void test() {
   
        System.out.println("oracle");
    }
}

service层

public interface UserService {
   
    void testService();
}

public class UserServiceImpl implements UserService {
   

    private UserDao userDao;

    public void testService() {
   
        userDao.test();
    }

    public void setUserDao(UserDao userDao) {
   
        this.userDao = userDao;
    }
}

配置文件

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="userDaoMysql" class="com.hznu.ch.dao.UserDaoMysqlImpl"/>
    <bean id="userDaoOracle" class="com.hznu.ch.dao.UserDaoOracleImpl"/>


    <bean id="userServiceImpl" class="com.hznu.ch.service.UserServiceImpl">
        <property name="userDao" ref="userDaoOracle"/>
    </bean>
</beans>

测试

public class MyTest {
   

    public static void main(String[] args) {
   
        ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext("beans.xml");
        UserService userServiceImpl = (UserService) ctx.getBean("userServiceImpl");
        userServiceImpl.testService();
    }
}

我们主要看一下配置文件,我们发现我们如果想把数据库改成mysql只需要把ref的值改成userDaoMysql即可,不在像以前一样去修改代码里的东西了

到了现在,我们彻底不用在程序中去改动了,要实现不同的操作,只需要在xml配置文件中进行修改,所谓的IOC,一句话搞定:对象由spring创建,管理,装配!

3.IOC创建对象的方式

1.构造器注入
  1. 使用无参构造创建
  2. 通过调用有参构造函数
<bean id="hello" class="com.hznu.ch.pojo.Hello">
    <constructor-arg index="0" value="chenheng"/>
    <constructor-arg index="1" value="123"/>
</bean>
  1. 通过调用有参构造函数(另一种方法)
<bean id="hello" class="com.hznu.ch.pojo.Hello">
    <constructor-arg type="java.lang.String" value="chendan"/>
    <constructor-arg type="int" value="321"/>
</bean>
2.set注入
  1. 这种方法是通过无参构造初始化的,再通过set来完成参数的注入的
<bean id="hello" class="com.hznu.ch.pojo.Hello">
    <property name="str" value="ch"/>
    <property name="age" value="116"/>
</bean>

小结:在配置文件加载的时候,容器中管理的对象就已经被初始化了

  1. 扩展IOC的使用
public class Address {
   

}
@Data
public class Student {
   
    private String name;
    private Address address;
    private String[] books;
    private List<String> hobbies;
    private Map<String, String> card;
    private Set<String> games;
    private String wife;
    private Properties info;
}
<bean id="student" class="com.hznu.ch.pojo.Student">
    <!--        字符串类型-->
    <property name="name" value="ch"/>

    <!--        引用类型-->
    <property name="address" ref="address"/>

    <!--        数组类型-->
    <property name="books">
        <array>
          <value>红楼梦</value>
          <value>三国演义</value>
          <value>水浒传</value>
          <value>西游记</value>
        </array>
    </property>

    <!--        list类型-->
    <property name="hobbies">
        <list>
          <value>打代码</value>
          <value>吃零食</value>
          <value>玩三国杀</value>
        </list>
    </property>

    <!--        map类型-->
    <property name="card">
        <map>
          <entry key="46" value="dd"/>
          <entry key="30" value="cd"/>
        </map>
    </property>


    <!--        set类型-->
    <property name="games">
        <set>
          <value>三国杀</value>
        </set>
    </property>

    <!--        null类型-->
    <property name="wife">
      	<null/>
    </property>

    <!--        properties-->
    <property name="info">
        <props>
          <prop key="性格">很傻很天真</prop>
        </props>
    </property>
</bean>
3.其他注入

命名空间的注入,需添加对应的约束

xmlns:p="http://www.springframework.org/schema/p"
xmlns:c="http://www.springframework.org/schema/c"
  1. p命名空间注入(通过set注入)
<!--两则等价-->
<bean id="teacher" class="com.hznu.ch.pojo.Teacher">
    <property name="name" value="ch"/>
    <property name="age" value="21"/>
</bean>

<bean id="teacher" class="com.hznu.ch.pojo.Teacher" p:age=
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 很抱歉,我是AI语言模型,无法回答关于“狂神说springsecurity笔记”的问题。但我可以告诉你,Spring Security是一个基于Spring框架的安全框架,用于保护Web应用程序。它提供了身份验证、授权、攻击防护等功能,可以帮助开发人员构建安全可靠的Web应用程序。狂神是一位知名的Java技术博主,他在自己的博客和视频中分享了很多关于Spring Security的知识和经验。如果你想学习Spring Security,可以参考他的笔记和教程。 ### 回答2: Spring Security 是一个强大的开源安全框架,用于保护 Spring 应用程序。它提供了一系列的安全服务,例如身份验证(Authentication)、授权(Authorization)、密码加密、会话管理等。 狂神在他的 Spring Security 笔记中详细介绍了该框架的使用方式和相关概念。首先,他解释了身份验证的重要性,提及了不同的身份验证方法,如基于表单的认证、基于记住我(Remember Me)的认证以及基于 HTTP Basic 和 Digest 验证等。他还介绍了如何自定义认证过程和处理认证失败的方法。 其次,狂神介绍了授权的概念和不同的授权方式。他解释了基于角色(Role)的访问控制和基于资源(Resource)的访问控制,并示范了如何在 Spring Security 中实现这些授权方式。他还介绍了如何使用注解和表达式来简化授权配置。 此外,狂神还介绍了 Spring Security 提供的其他功能,如密码加密、会话管理、防止跨点请求伪造(CSRF)攻击等。他指导读者如何使用这些功能来增强应用程序的安全性。 总的来说,狂神的 Spring Security 笔记对于初学者来说是一个很好的入门指南。他提供了丰富的示例代码和详细解释,让读者可以很容易地理解和使用 Spring Security。无论是开发 Web 应用程序还是企业级应用程序,掌握 Spring Security 都是非常重要的,狂神的笔记提供了一个很好的起点。 ### 回答3: spring security 是一个开源的安全框架,可以为应用程序提供身份验证和授权管理的功能。它基于 JavaEE 标准认证和授权机制,并提供了一套更灵活的安全性管理机制。 首先,Spring Security 实现了用户认证的功能,可以通过多种认证方式来验证用户的身份,包括基于数据库的认证、LDAP 认证、OAuth2 认证等。可以根据具体的需求选择使用不同的认证方式。 其次,Spring Security 提供了授权管理的功能,可以设置不同的权限角色,对不同的用户进行授权。可以通过配置的方式进行权限的控制,通过注解或者编程的方式进行细粒度的控制,可以灵活地满足不同的应用需求。 另外,Spring Security 还提供了许多其他的安全支持功能,如防止 CSRF 攻击、防止点击劫持、防止 SQL 注入等。它还支持与其他框架的集成,如与 Spring Boot、Spring MVC 的集成,可以方便地在现有的应用中集成安全功能。 Spring Security 的架构清晰,易于理解和使用。它的设计模式和扩展机制可以满足不同级别的定制需求,使得我们可以根据实际情况来灵活地进行使用和扩展。同时,Spring Security 还提供了丰富的文档和示例代码,方便开发者学习和使用。 总之,Spring Security 是一个功能强大且灵活的安全框架,可以在应用程序中实现身份验证和授权管理的功能。通过使用 Spring Security,我们可以有效地保护和管理我们的应用程序,提升系统的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值