需求背景:
有的下游渠道不提供回执单,但是商户却又需要,就只能通过程序自动生成了;这些回执单的数据其实都是交易流程中的一些关键数据,交易流水、金额、币种等等。
解决方案:
新建一个独立的服务,专门用来生成PDF格式的回执单,采用Thymeleaf+flying-saucer-pdf用来生成本地路径的PDF。spring-integration-sftp用来把本地路径的PDF上传到指定目录。Thymeleaf可以很灵活的控制PDF格式。
核心点:
- 创建日期目录没有权限:需要切换到目标目录之后,再执行mkDir,不能在外层直接创建目录。
- java.io.File的运用;SFTP协议;RabbitMQ;策略;面向接口;抽象公共属性;
架构图:
设计到的知识点:
- FTP:
FTP全称是File Transfer Protocol(文件传输协议),默认端口:21。
FTP的任务是从一台计算机将文件传送到另一台计算机,不受操作系统的限制。 - SFTP:
SFTP是Secure File Transfer Protocol的缩写,安全文件传送协议。
SFTP同样是使用加密传输认证信息和传输的数据,所以,使用SFTP是非常安全的。
但是,由于这种传输方式使用了加密/解密技术,所以传输效率比普通的FTP要低得多,如果您对网络安全性要求更高时,可以使用SFTP代替FTP。 - 协议:
协议其实就是一组约定好的规范,交流的双方按照约定的规则,去编码、解码对应的数据,获取对应位置的内容,做相应的判断。
二进制流在网络上传输,其实物理上也都是写电信号。 -
其他:
字节流在操作的时候是不会用到缓冲区的。
字符流在操作的时候是会用到缓冲区的。
字(Byte)节是长度单位。位(bit)也是长度单位。
计算机通信和存储的时候都是以010101这样的二进制数据为基础,一个0或者1占的地方就叫bit(位),即一个二进制位。
1Byte=8bit
1KB=1024B
1MB=1024KB(2的十次方)
二进制数中只有两个字符0和1,表示具有两个不同稳定状态的元器件。
在程序中所有的数据都是以流的方式进行传输或保存,流中保存的实际上是字节文件。
InputStream 和OutputStream,两个是为字节流设计的,主要用来处理字节或二进制对象。
Reader和 Writer.两个是为字符流(一个字符占两个字节)设计的,主要用来处理字符或字符串。
- RabbitMQ:
RabbitMQ遵循AMQP协议,RabbitMQ的broker由Exchange,Binding,queue组成。
长连接,queue有消息会推送到consumer端,consumer循环从输入流读取数据。
rabbitMQ以broker为中心;有消息的确认机制。 - Kafka:
kafka遵从一般的MQ结构,producer,broker,consumer,以consumer为中心,消息的消费信息保存的客户端consumer上,consumer根据消费的点,从broker上批量pull数据;无消息确认机制。 -
策略模式:
定义一组算法,将每个算法都封装起来,并且使他们之间可以互换。
策略接口的返回值其实可以定义成泛型或者Object类型的,这样更具有扩展性。
Context叫做上下文角色,起承上启下封装作用,屏蔽高层模块对策略、算法的直接访问,封装可能存在的变化。
JDK策略模式的应用:
总结:
经常反思,总结,讨论...