springboot如何解决非controller类引用service的问题

 更新时间:2022年02月24日 14:58:20   作者:xiexiangyan  
这篇文章主要介绍了springboot如何解决非controller类引用service的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

解决非controller类引用service问题

项目中遇到需要采用socket通信机制,由于这个方法没有写在控制类里面,调用service类的时候老是报java.lang.NullPointerException错误

解决办法

1、首先将@Autowired注解注入Service或者Mapper接口

 @Autowired
    PaUserService pauserService;

2、设置静态变量

private static DomSocketUtils domSocketUtils;

3、初始化静态变量,注意要添加 @PostConstruct注解

 @PostConstruct  //用于在依赖关系注入完成之后需要执行的方法上,以执行任何初始化
    public void init() {
        domSocketUtils = this;
    }

总的代码如下

@Component()
public class DomSocketUtils extends ServerSocket {
    @Autowired
    PaUserService pauserService;
    private static final int SERVER_PORT = 8875; // 服务端端口
    private static DomSocketUtils domSocketUtils;
    private ServerSocket server;
    //    @PostConstruct
    public DomSocketUtils() throws Exception {
//        server=new ServerSocket(SERVER_PORT);
//        load();
    }
    @PostConstruct  //用于在依赖关系注入完成之后需要执行的方法上,以执行任何初始化
    public void init() {
        domSocketUtils = this;
    }
    /**
     * 使用线程处理每个客户端传输的文件
     * @throws Exception
     */
    @Async("taskExexutor")
    public void load() throws Exception {
        server=new ServerSocket(SERVER_PORT);
        while (true) {
            System.out.println("-----------等待连接-------- ");
            Socket socket = server.accept();//接收连接服务端的客户端对象
            System.out.println("ip" + socket.getInetAddress() + "已连接");
            new Thread(new Transfer(socket),"thread1").start();// 每接收到一个Socket就建立一个新的线程来处理它
            System.out.println(Thread.currentThread().getName());
        }
    }
    /**
     * 处理客户端传输过来的文件线程类
     */
    class Transfer implements Runnable {
        private Socket socket;
        private DataInputStream dis;
        private FileOutputStream fos;
        public Transfer(Socket socket) {
            this.socket = socket;
        }
        @Override
        public void run() {
            try {
                dis = new DataInputStream(socket.getInputStream());
                // 文件名和长度
                String imageurl="";
                String fileName = dis.readUTF(); //获取文件名
                long fileLength = dis.readLong();
                File directory = new File("E://"); //创建绝对路径
                if(!directory.exists()) {
                    directory.mkdir();
                }
                File file = new File("E://");
                fos = new FileOutputStream(basepath);//存入文件
                // 开始接收文件
                byte[] bytes = new byte[1024];
                int length = 0;
                while((length = dis.read(bytes, 0, bytes.length)) != -1) {
                    fos.write(bytes, 0, length);
                    fos.flush();
                }
                File file1 = new File(basepath);//读取文件
                DicomInputStream dis = new DicomInputStream(file1);
                Attributes fmi = dis.readFileMetaInformation();
                Attributes attrs = dis.readDataset(-1, -1);
                PaUser  role = domSocketUtils.pauserService.getpaUserRole1(attrs.getString(Tag.PatientID));//验证是否存在该病人
                System.out.println("======== 文件接收成功 [File Name:" + fileName + "] ");
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                try {
                    if(fos != null)
                        fos.close();
                    if(dis != null)
                        dis.close();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    }

注:socket文件接收的是dicom文件

在非controller层如何调用service层服务

通过init方法进行服务注入

@Slf4j
@Component
public class ServerIOT {
    @Resource
    private EasybandDateService easybandDateService;
    @PostConstruct //通过@PostConstruct实现初始化bean之前进行的操作
    public void init() {
        serverIOT = this;
        serverIOT.easybandDateService = this.easybandDateService;
        // 初使化时将已静态化的easybandDateService实例化
    }
}

调用方法形式如下

在前面添加当前类就可以了

boolean save = serverIOT.easybandDateService.save(easybandDate);

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Spring之从桥接方法到JVM方法调用解读

    Spring之从桥接方法到JVM方法调用解读

    这篇文章主要介绍了Spring之从桥接方法到JVM方法调用解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • Maven打包并生成运行脚本的示例代码

    Maven打包并生成运行脚本的示例代码

    这篇文章主要介绍了Maven打包并生成运行脚本,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • IntelliJ IDEA2020.1 Mac maven sdk 全局配置

    IntelliJ IDEA2020.1 Mac maven sdk 全局配置

    这篇文章主要介绍了IntelliJ IDEA2020.1 Mac maven sdk 全局配置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • SpringSecurityOAuth2 如何自定义token信息

    SpringSecurityOAuth2 如何自定义token信息

    这篇文章主要介绍了SpringSecurityOAuth2 自定义token信息的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java集合类的组织结构和继承、实现关系详解

    Java集合类的组织结构和继承、实现关系详解

    这篇文章主要介绍了Java集合类的组织结构和继承、实现关系,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Java使用JDK与Cglib动态代理技术统一管理日志记录

    Java使用JDK与Cglib动态代理技术统一管理日志记录

    这篇文章主要介绍了Java使用JDK与Cglib动态代理技术统一管理日志记录,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05
  • 利用Java如何获取Mybatis动态生成的sql接口实现

    利用Java如何获取Mybatis动态生成的sql接口实现

    MyBatis 的强大特性之一便是它的动态SQL,下面这篇文章主要给大家介绍了关于利用Java如何获取Mybatis动态生成的sql接口实现的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-01-01
  • 使用SpringSecurity设置角色和权限的注意点

    使用SpringSecurity设置角色和权限的注意点

    这篇文章主要介绍了使用SpringSecurity设置角色和权限的注意点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • spring+springmvc+mybatis 开发JAVA单体应用

    spring+springmvc+mybatis 开发JAVA单体应用

    这篇文章主要介绍了spring+springmvc+mybatis 开发JAVA单体应用的相关知识,本文通过图文实例代码的形式给大家介绍的非常详细 ,需要的朋友可以参考下
    2018-11-11
  • Java雪花算法的原理和实现方法

    Java雪花算法的原理和实现方法

    这篇文章主要介绍了Java雪花算法的原理和实现方法,雪花算法是一种分布式唯一ID生成算法,可以生成全局唯一的ID标识符,就像自然界中雪花一般没有相同的雪花,下面将详细介绍,感兴趣的可以学习一下
    2023-10-10

最新评论