学号 20175313 《实验三 敏捷开发与XP实践》实验报告

本文详细介绍了Java编码标准的实践,包括IDEA代码格式化、重构技巧、Git协作流程,以及Java密码学的学习,涉及对称加密、非对称加密和摘要算法的运用。

一、实验内容

(1)编码标准

在IDEA中使用工具(Code->Reformate Code)把下面代码重新格式化,再研究一下Code菜单,找出一项让自己感觉最好用的功能。

public class CodeStandard {
public static void main(String [] args){
StringBuffer buffer = new StringBuffer();
buffer.append('S');
buffer.append("tringBuffer");
System.out.println(buffer.charAt(1));
System.out.println(buffer.capacity());
System.out.println(buffer.indexOf("tring"));
System.out.println("buffer = " + buffer.toString());
if(buffer.capacity()<20)
buffer.append("1234567");
for(int i=0; i<buffer.length();i++)
System.out.println(buffer.charAt(i));
}
}
(2)Git的使用

在码云上把自己的学习搭档加入自己的项目中,确认搭档的项目加入自己后,下载搭档实验二的Complex代码,加入不少于三个JUnit单元测试用例,测试成功后git add .; git commit -m "自己学号 添加内容";git push。

(3)重构

完成重构内容的练习,下载搭档的代码,至少进行三项重构,提交重构后代码的截图,加上自己的学号水印。提交搭档的码云项目链接。

(4)Java密码学相关内容的学习

参考 http://www.cnblogs.com/rocedu/p/6683948.html,以结对的方式完成Java密码学相关内容的学习,结合重构,git,代码标准。

二、实验步骤

(1)编码标准
  • 没有规范前:

    131128_87885c8b_4784913.png

  • 单击IDEA菜单中的Code->Reformat 或用快捷键Ctrl+Alt+L就可以按IDEA规定的规范缩进。

    131146_56043d2d_4784913.png

  • 效果如下:

    131201_c5fcaa98_4784913.png

  • Java中的一般的命名规则有:
1.要体现各自的含义
2.包、类、变量用名词
3.方法名用动宾
4.包名全部小写,如:io,awt
5.类名第一个字母要大写,如:HelloWorldApp
6.变量名第一个字母要小写,如:userName
7.方法名第一个字母要小写:setName

更多详情请参见邹欣老师写的代码规范与代码复审

  • Code菜单中让我感觉最好用的功能:
    • Surround With ( 生成包围代码 ) Ctrl + Alt +T
    • Unwarp/Remove ( 取消代码包围 ) Ctrl + Shift + Delete
    • Move Statement Down ( 方法、代码下移 ) Ctrl + Shift + 向下箭头
    • Move Statement Up ( 方法、代码上移 ) Ctrl + Shift + 向上箭头

更多详情请参见IDEA快捷键拆解系列(六):Code篇

  • 说明:因为我之前安装过alibaba 插件,所以就没有将其安装过程写入本次试验。详情请参见Intellj IDEA 简易教程
(2)Git的使用以及添加Complex类测试代码
  • 自己的学习搭档加入自己的项目中

    130014_6482bb8a_4784913.png
    130105_e037bab6_4784913.png

  • 添加搭档的Complex类测试代码

    130717_7c73ac82_4784913.png

  • 码云上传成功截图:

    133420_f1f698e8_4784913.png
    111001_4400df0c_4784913.png
    111014_b647503b_4784913.png

(3)重构

针对编码规约扫描提出的问题一一解决。

  • 问题1:包名应为全部小写字母和数字组成。
  • 解决方法:右击包名->Refactor->Rename,进行重命名。

    120834_9c37b5f4_4784913.png

  • 问题2:所有的类都必须添加创建者信息

    122648_bf966783_4784913.png

  • 解决方法:按照下面的格式,添加作者和日期。

    122552_c99a4fe0_4784913.png

  • 问题3:类、类属性、类方法必须用javadoc规范

    123255_c430c728_4784913.png

  • 解决方法:将注释格式改完/**内容*/

    123623_d2789d57_4784913.png

  • 问题4:方法名、参数名、成员变量、局部变量没有遵从驼峰形式

    123804_3189ba11_4784913.png

  • 解决方法:将要修改的变量单击右键,Refactor->Rename,进行重命名,这样能够批量的进行修改,不用自己一个一个的改。
  • 修改后代码截图:

    133616_e2f78099_4784913.png

(4)Java密码学相关内容的学习
  • 体验加解密-凯撒密码
    • 加密:c≡m+k mod n
    • 解密:m≡c+k mod n

      215539_6b3139a6_4784913.png
      215630_67c615c9_4784913.png

  • Java对称加密-DES算法

    1. 获取密钥生成器:KeyGenerator kg=KeyGenerator.getInstance("DESede");
    2. 初始化密钥生成器:kg.init(168);
    3. 生成密钥:SecretKey k=kg.generateKey( );
    • 以对象保存在文件中:通过对象序列化方式将密钥保存在文件中:FileOutputStream f=new FileOutputStream("key1.dat");
      ObjectOutputStream b=new ObjectOutputStream(f);
      b.writeObject(k);

      215813_bd9a36d4_4784913.png

    • 以字节保存在文件中:
      • 获取密钥
      • 获取主要编码格式
      • 保存密钥编码格式

        222426_6de5196e_4784913.png

    • 加密“Hello World!”

      224024_0e09d8c7_4784913.png

    • 对“Hello World!”生成的密文解密

      225717_79f74ccd_4784913.png

  • Java非对称加密-RSA算法

    231804_c380c531_4784913.png

    • 加密“Hello World!”

      000022_0dd1a2f0_4784913.png

    • 对“Hello World!”生成的密文解密

      000248_2abfeaf0_4784913.png

  • 使用密钥协定创建共享密钥
    • 创建DH公钥和私钥
      • A生成的公钥和私钥

        003015_10526452_4784913.png

      • B生成的公钥和私钥

        003434_1cae1d30_4784913.png

    • 创建共享密钥

      005858_7eef5328_4784913.png

  • Java摘要算法- MD5

    010930_2f2b595c_4784913.png

三、实验过程中遇到的问题及其解决方法

  • 问题:对于凯撒密码的加解密,之前做密码学实验的时候,自己用java实现过,对于其中的加解密,很是烦躁,因为明文是字符型加上密钥作为偏移量,一进行运算就会变成整数,然后还得从整数转回字符,还要考虑是否超出26。

    014148_582e10d3_4784913.png

  • 解决方法:通过本次学习,我发现将c=c+(key%26)缩写成c+=key%26;就可以很好的解决这个问题。
  • 之前我的解决办法:

    014509_2e760c07_4784913.png

四、心得体会

  • 这次实验内容大部分我之前都解决过了,所以没有什么问题。
  • 就是看别人的程序有点吃力,我搭档用的很多高级方法我都没见过,需要经常查看帮助文档才能勉强理解,但是也扩宽了我的视野。
  • 本次实验,对我来说收获最大的应该就是学会了代码的规范,规范后的代码看起来真的很舒服。
  • 补:学了Java Collections API和泛型以及java密码学算法,
    真的是受益匪浅。相当于复习了一遍数据结构和密码学,虽然并没有介绍算法的内核,但是让我学会了如何使用各种加解密算法的使用。
  • 链接里几乎对每句代码都有详细的解释,所以学起来并不难,就是内容有点多,但是看到后面就会发现其实都差不多,所以总的来说本次实验还是学到了不少东西。

五、码云链接

六、结对成员链接

七、参考资料

转载于:https://www.cnblogs.com/xiannvyeye/p/10790082.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值