一、实验内容

  • 1、编码标准:在IDEA中使用工具(Code->Reformate Code)把下面代码重新格式化,再研究一下Code菜单,找出一项让自己感觉最好用的功能。提交截图,加上自己学号水印。
  • 2、搭档代码检验:在码云上把自己的学习搭档加入自己的项目中,确认搭档的项目加入自己后,下载搭档实验二的Complex代码,加入不少于三个JUnit单元测试用例,测试成功后git add .; git commit -m "自己学号 添加内容";git push;
  • 3、重构:完成重构内容的练习,下载搭档的代码,至少进行三项重构
  • 4、以结对的方式完成Java密码学相关内容的学习,结合重构,git,代码标准。

二、实验步骤

  • 1.编码标准

    • 在扩展包处搜索alibaba并下载,安装完成后重启:

    • 在要进行规范的文件右键选择 “编码规约扫描”开始扫描:

  • 规范前给出的不规范内容提示如下:

  • 规范后的代码如下:

  • Java中的一般的命名规则有:

    • 要体现各自的含义
    • 包、类、变量用名词
    • 方法名用动宾
    • 包名全部小写,如:io,awt
    • 类名第一个字母要大写,如:HelloWorldApp
    • 变量名第一个字母要小写,如:userNamege
    • 方法名第一个字母要小写:setName
  • Code菜单中的一些功能

    • Override Methods(ctrl+O):重载基本类的方法

    • Surround With(Ctrl+Alt+T):使用if-else、for、while等语句包装代码段

    • omment with Line Comment(Ctrl+/):将本行变成注释

    • Comment with Block Comment(Ctrl+Shift+/):将选中的代码块变成注释

    • Move Statement Down ( 方法、代码下移 ) 快捷键:Ctrl + Shift + 向下箭头

    • Move Statement Up ( 方法、代码上移 )快捷键: Ctrl + Shift + 向上箭头





  • 2.测试搭档代码

    • 获得伙伴仓库权限

      • 登陆伙伴的码云仓库,在管理中选择仓库成员管理,—>添加仓库成员—>邀请用户,然后直接手机扫码或者复制链接



    • 搭档代码如下:

package Experiment;

public class ComplexWZH {
double realPart;
double imagePart;
public ComplexWZH() {}
public ComplexWZH(double r, double i) {
realPart = r;
imagePart = i;
}
public double getRealPart() {
return realPart;
}
public double getImagePart() {
return imagePart;
}
@Override
public boolean equals(Object obj) {
if(this == obj) {
return true;
}
if(obj == null) {
return false;
}
if(getClass() != obj.getClass()) {
return false;
}
if(!(obj instanceof ComplexWZH)) {
return false;
} else {
ComplexWZH complexWZH = (ComplexWZH) obj;
if (complexWZH.imagePart == ((ComplexWZH) obj).imagePart) {
return true;
}
if (complexWZH.realPart == ((ComplexWZH) obj).realPart) {
return true;
}
}
return false;
}
@Override
public String toString() {
String str = "";
if (realPart == 0&& imagePart == 0) {
str = "0.0";
} else if (realPart == 0&& imagePart != 0) {
str = imagePart + "" + "i";
} else if (realPart != 0&& imagePart == 0) {
str = realPart + "";
} else if (realPart !=0&& imagePart > 0) {
str = realPart + "" + "+" + imagePart + "i";
} else if (realPart !=0&& imagePart < 0) {
str = realPart + "" + imagePart + "i";
}
return str;
}
public ComplexWZH complexAdd(ComplexWZH a) {
return new ComplexWZH(realPart + a.getRealPart(), imagePart + a.getImagePart());
}
public ComplexWZH complexSub(ComplexWZH a) {
return new ComplexWZH(realPart - a.getRealPart(), imagePart - a.getImagePart());
}
public ComplexWZH complexMulti(ComplexWZH a) {
return new ComplexWZH(realPart *a.getRealPart() - imagePart *a.getImagePart(), realPart *a.getImagePart() + imagePart *a.getRealPart());
}
public ComplexWZH complexDiv(ComplexWZH a) {
if(a.getRealPart() == 0&&a.getImagePart() == 0) {
System.out.println("除数不能为0");
return new ComplexWZH();
}
else {
return new ComplexWZH((realPart *a.getRealPart() - imagePart *a.getImagePart())/(a.getRealPart()*a.getRealPart()-a.getImagePart()*a.getImagePart()),(realPart *a.getImagePart() + imagePart *a.getRealPart())/(a.getRealPart()*a.getRealPart()-a.getImagePart()*a.getImagePart()));
}
}
}
  • 对其中的所有方法均进行了测试

  • 测试代码:

package Experiment;

import junit.framework.TestCase;
import org.junit.Test;
public class ComplexWZHTest extends TestCase {
ComplexWZH a = new ComplexWZH(2.0,5.0);
ComplexWZH b = new ComplexWZH(1.0,-4.0);
ComplexWZH c = new ComplexWZH(-3.0,2.0);
ComplexWZH d = new ComplexWZH(-4.0,-3.0);
ComplexWZH e = new ComplexWZH(0.0,0.0);
@Test
public void testgetRealPart() throws Exception {
assertEquals(2.0,a.getRealPart());
assertEquals(1.0,b.getRealPart());
assertEquals(-3.0,c.getRealPart());
assertEquals(-4.0,d.getRealPart());
assertEquals(0.0,e.getRealPart());
}
@Test
public void testgetImagePart() throws Exception {
assertEquals(5.0,a.getImagePart());
assertEquals(-4.0,b.getImagePart());
assertEquals(2.0,c.getImagePart());
assertEquals(-3.0,d.getImagePart());
assertEquals(0.0,e.getImagePart());
}
@Test
public void testequals() throws Exception {
assertEquals(true,a.toString().equals(a.toString()));
assertEquals(false,b.toString().equals(c.toString()));
assertEquals(false,d.toString().equals(e.toString()));
}
@Test
public void testtoString() throws Exception {
assertEquals("2.0+5.0i",a.toString());
assertEquals("1.0-4.0i",b.toString());
assertEquals("-3.0+2.0i",c.toString());
assertEquals("-4.0-3.0i",d.toString());
assertEquals("0.0",e.toString());
}
@Test
public void testComplexAdd() throws Exception {
assertEquals("3.0+1.0i",a.ComplexAdd(b).toString());
assertEquals("-7.0-1.0i",c.ComplexAdd(d).toString());
assertEquals("-4.0-3.0i",d.ComplexAdd(e).toString());
}
@Test
public void testComplexSub() throws Exception {
assertEquals("1.0+9.0i",a.ComplexSub(b).toString());
assertEquals("1.0+5.0i",c.ComplexSub(d).toString());
assertEquals("-3.0+2.0i",c.ComplexSub(e).toString());
}
public void testComplexMulti() throws Exception {
assertEquals("22.0-3.0i",a.ComplexMulti(b).toString());
assertEquals("18.0+1.0i",c.ComplexMulti(d).toString());
assertEquals("0.0",b.ComplexMulti(e).toString());
}
public void testComplexDiv() throws Exception {
assertEquals("-1.4666666666666666+0.2i",a.ComplexDiv(b).toString());
assertEquals("2.5714285714285716+0.14285714285714285i",c.ComplexDiv(d).toString());
assertEquals("0.0",a.ComplexDiv(e).toString());
}
}
  • 测试结果:

  • 将测试好的代码push至伙伴的码云并git log

  • 3.重构

    • 对代码进行如下重构

      • 重写方法加上@Override进行注解

      • 在代码前添加创建者的相关信息

      • 方法名、参数名、成员变量、局部变量都统一使用LowerCamelCase,必须遵从驼峰形式,重构前提示

    • 重构后代码:

/**
* ComplexWZH
* @author 林郅聪
* @date 2019/5/1
*/
package Experiment; @SuppressWarnings({"ALL", "AlibabaLowerCamelCaseVariableNaming"})
public class ComplexWZH {
@SuppressWarnings("AlibabaLowerCamelCaseVariableNaming")
double realPart;
double imagePart;
public ComplexWZH() {}
public ComplexWZH(double r, double i) {
realPart = r;
imagePart = i;
}
public double getRealPart() {
return realPart;
}
public double getImagePart() {
return imagePart;
}
@Override
public boolean equals(Object obj) {
if(this == obj) {
return true;
}
if(obj == null) {
return false;
}
if(getClass() != obj.getClass()) {
return false;
}
if(!(obj instanceof ComplexWZH)) {
return false;
} else {
ComplexWZH complexWZH = (ComplexWZH) obj;
if (complexWZH.imagePart == ((ComplexWZH) obj).imagePart) {
return true;
}
if (complexWZH.realPart == ((ComplexWZH) obj).realPart) {
return true;
}
}
return false;
}
@Override
public String toString() {
String str = "";
if (realPart == 0&& imagePart == 0) {
str = "0.0";
} else if (realPart == 0&& imagePart != 0) {
str = imagePart + "" + "i";
} else if (realPart != 0&& imagePart == 0) {
str = realPart + "";
} else if (realPart !=0&& imagePart > 0) {
str = realPart + "" + "+" + imagePart + "i";
} else if (realPart !=0&& imagePart < 0) {
str = realPart + "" + imagePart + "i";
}
return str;
}
public ComplexWZH complexAdd(ComplexWZH a) {
return new ComplexWZH(realPart + a.getRealPart(), imagePart + a.getImagePart());
}
public ComplexWZH complexSub(ComplexWZH a) {
return new ComplexWZH(realPart - a.getRealPart(), imagePart - a.getImagePart());
}
public ComplexWZH complexMulti(ComplexWZH a) {
return new ComplexWZH(realPart *a.getRealPart() - imagePart *a.getImagePart(), realPart *a.getImagePart() + imagePart *a.getRealPart());
}
public ComplexWZH complexDiv(ComplexWZH a) {
if(a.getRealPart() == 0&&a.getImagePart() == 0) {
System.out.println("除数不能为0");
return new ComplexWZH();
}
else {
return new ComplexWZH((realPart *a.getRealPart() - imagePart *a.getImagePart())/(a.getRealPart()*a.getRealPart()-a.getImagePart()*a.getImagePart()),(realPart *a.getImagePart() + imagePart *a.getRealPart())/(a.getRealPart()*a.getRealPart()-a.getImagePart()*a.getImagePart()));
}
}
}

-4.Java密码学相关内容

  • Java安全体系结构总共分为4个部分:

  • JCAJava Cryptography Architecture, Java加密体系结构):JCA提供基本的加密框架, 如证书、 数字签名、消息摘要和密钥对产生器。

  • JCEJava Cryptography Extension, Java加密扩展包): JCEJCA的基础上作了扩展, 提供了各种加密算法、 消息摘要算法和密钥管理等功能。JCE的实现主要在javax.crypto包( 及其子包) 中

  • JSSEJava Secure Sockets Extension, Java安全套接字扩展包):JSSE提供了基于SSL Secure Sockets Layer,安全套接字层) 的加密功能。 在网络的传输过程中, 信息会经过多个主机(很有可能其中一台就被窃听) , 最终传送给接收者, 这是不安全的。这种确保网络通信安全的服务就是由JSSE来提供的。

  • JAASJava Authentication and Authentication Service, Java鉴别与安全服务):JAAS提供了在Java平台上进行用户身份鉴别的功能。

  • 凯撒密码

    • 对凯撒密码进行了验证,并对代码进行了重构

    • 运行结果

    • 重构后结果

    • Java对称加密—DES算法

    • 密钥的产生



    • 加密Hello World

    • 对密文进行解密

    • Java非对称加密—RSA算法

    • 公私钥的产生

    • 加密Hello World

    • 对密文进行解密

    • 使用密钥协定创建共享密钥—DH算法

    • A和B分别产生自己的公钥和私钥

    • 创建共享密钥

    • Java摘要算法—MD5

三、实验中遇到的问题

  • 问题:在实现DH算法时,希望把用户A和B的产生的公钥和私钥分别存放至两个目录中,但实际上不能做到放至同一个包下,在out文件中运行时会自动存放至根目录下,无法真正实现博客中所说的个人用户的管理
  • 解决方法:暂无

四、伙伴评价

伙搭档学习热情很高,一直督促我学习,过程中也帮助我很多,是很好的学习伙伴。

五、码云链接

我的码云链接:链接

伙伴的码云链接:链接

2018-2019-2 20175214 实验三《敏捷开发与XP实践》实验报告的更多相关文章

  1. 20165230 《Java程序设计》实验三 敏捷开发与XP实践 实验报告

    20165230 <Java程序设计>实验三 敏捷开发与XP实践 实验报告 一.实验报告封面 课程:Java程序设计 班级:1652班 姓名:田坤烨 学号:20165230 成绩: 指导教 ...

  2. 20175212童皓桢 实验三敏捷开发与XP实践实验报告

    20175212童皓桢 实验三敏捷开发与XP实践实验报告 实验内容 XP基础 XP核心实践 相关工具 实验步骤 一.Code菜单功能的研究 Move Line/statement Down/Up:将某 ...

  3. 20145308刘昊阳 《Java程序设计》实验三 敏捷开发与XP实践 实验报告

    20145308刘昊阳 <Java程序设计>实验三 敏捷开发与XP实践 实验报告 实验名称 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 统计的PSP(Personal ...

  4. 20162311 实验三 敏捷开发与XP实践 实验报告

    20162311 实验三 敏捷开发与XP实践 实验报告 实验内容 一.研究学习IDEA中的Code菜单 使用Code ->Reformate Code功能将以下代码格式化 public clas ...

  5. 20165308实验三 敏捷开发与XP实践实验报告

    实验三 敏捷开发与XP实践实验报告 实验目的 安装 alibaba 插件,解决代码中的规范问题.再研究一下Code菜单,找出一项让自己感觉最好用的功能. 在码云上把自己的学习搭档加入自己的项目中,确认 ...

  6. 20155207王雪纯 《Java程序设计》实验三 敏捷开发与XP实践 实验报告

    20155207王雪纯 <Java程序设计>实验三 敏捷开发与XP实践 实验报告 实验名称 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 统计的PSP(Personal ...

  7. 20155220 实验三 敏捷开发与XP实践 实验报告

    20155220 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 XP核心实践 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

  8. # 20155224 实验三 敏捷开发与XP实践 实验报告

    20155224 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 XP核心实践 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

  9. 20155226 实验三 敏捷开发与XP实践 实验报告

    20155226 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 XP核心实践 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

  10. 20155311 实验三 敏捷开发与XP实践 实验报告

    20155311 实验三 敏捷开发与XP实践 实验报告 实验内容 XP基础 xp核心工具 相关工具 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)><Vim ...

随机推荐

  1. 【监控笔记】【3.1】DML(CDC)、DDL(DDL触发器)跟踪数据更改,数据库审计

    关键词:数据库审计.DDL审计.DML审计 [监控笔记][3.1]DML(CDC).DDL(DDL触发器)跟踪数据更改 [1]DML(CDC) 2008及以上 https://www.cnblogs. ...

  2. ES5中的继承

    继承 在面向对象的语言中, 大多语言都支持两种继承方式: 接口继承 和 实现继承, 接口继承 只继承方法签名, 实现继承 才继承实际的方法, ECMAScript 值支持 实现继承, 今天我们来谈谈实 ...

  3. 小白学Python(19): Pyinstaller 生成 exe 文件

    python 默认并不包含 PyInstaller 模块,因此需要自行安装 PyInstaller 模块. 安装 PyInstaller 模块与安装其他 Python 模块一样,使用 pip 命令安装 ...

  4. Python 入门之 Python三大器 之 装饰器

    Python 入门之 Python三大器 之 装饰器 1.开放封闭原则: (1)代码扩展进行开放 ​ 任何一个程序,不可能在设计之初就已经想好了所有的功能并且未来不做任何更新和修改.所以我们必须允许代 ...

  5. Solr安装(单机版)

    本文记录的是solr在win下安装配置使用的过程,最后将solr部署到Linux上通过远程访问.下一篇文章会介绍   solr集群搭建(SolrCloud)    的安装! Solr是基于Lucene ...

  6. webpack收藏

    收藏链接: https://www.jianshu.com/p/8ff8e71dcbc6

  7. netdevice - 底层访问 Linux 网络设备

    总览 (SYNOPSIS) #include <sys/ioctl.h> #include <net/if.h> 描述 (DESCRIPTION) 本手册 描述 用于 配置 网 ...

  8. JavaEE高级-JPA学习笔记

    *JPA概述 *JPA是什么? - Java Persistence API :用于对象持久化的API - Java EE 5.0平台标准的ORM规范,使得应用程序以统一的方式访问持久化层 - JPA ...

  9. macos升级Nodejs和Npm到最新版

    第一步,先查看本机node.js版本: node -v 第二步,清除node.js的cache: sudo npm cache clean -f 第三步,安装 n 工具,这个工具是专门用来管理node ...

  10. WPF导出发布安装包,无法验证发行者解决办法

    右击工程项目点发布->完成 此时在工程目录下生成了安装文件setup.exe 同时又在工程下生成了临时证书WpfApp1_TemporaryKey.pfx 如果此时强行安装会弹出如下警告 接下来 ...