一、实验报告封面

课程:Java程序设计 班级:1653班 姓名:杨金川 学号:20165323

指导教师:娄嘉鹏 实验日期:2018年4月28日

实验时间:13:45 - 15:25 实验序号:实验三

实验名称:敏捷开发与XP实践

实验内容:

1、XP基础

2、XP核心实践

3、相关工具

实验要求:

1、没有Linux基础的同学建议先学习《Linux基础入门(新版)》《Vim编辑器》 课程;

2、完成实验、撰写实验报告,注意实验报告重点是运行结果,遇到的问题(工具查找,安装,使用,程序的编辑,调试,运行等)、解决办法(空洞的方法如“查网络”、“问同学”、“看书”等一律得0分)以及分析(从中可以得到什么启示,有什么收获,教训等);

3、实验报告中统计自己的PSP(Personal Software Process)时间;

4、严禁抄袭。

二、实验步骤

(1)安装alibaba 插件,解决代码中的规范问题。在IDEA中使用工具(Code->Reformate Code)把下面代码重新格式化,再研究一下Code菜单,找出一项让自己感觉最好用的功能。

运行截图:

修改前:



修改后:



code菜单中功能的应用

Override Methods(Ctrl+O):重载基本类的方法;

Implement Methods(Ctrl+I):完成当前类 implements 的(或者抽象基本类的)接口的方法;

Generate(Alt+Insert):创建类里面任何字段的 getter 与 setter 方法;

Surround With(Ctrl+Alt+T):使用if-else、try-catch、do-while等包装代码段;

我觉得好用的功能是Surround With



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

结果截图:





(3)实验三 敏捷开发与XP实践 http://www.cnblogs.com/rocedu/p/4795776.html, Eclipse的内容替换成IDEA

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

知识点:



结果截图:

原代码:



修改之后:

(4)以结对的方式完成Java密码学相关内容的学习,结合重构、git、代码标准等

知识点:

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

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

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

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

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

我们小组此次实现了希尔密码

import java.util.Scanner;

public class Hill {

    static int[][] key = {
{17, 17, 5},
{21, 18, 21},
{2, 2, 19},
}; static int[] temp = {
1, 0, 0,
}; public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input = new Scanner(System.in );
Hill hill = new Hill();
System.out.println("请输入需要希尔密码加密的明文:");
String plainttext = input.nextLine(); String ciphertext = hill.getEncrypttext(plainttext.toUpperCase());
System.out.println(ciphertext); System.out.println();
System.out.println("下面将上面的密文重新通过加密密钥来解密");
String plainttext2 = hill.getDncrypttext(ciphertext); System.out.println("解密后的明文为:");
System.out.println(plainttext2.toLowerCase()); input.close();
} private String getDncrypttext(String ciphertext) {
// TODO Auto-generated method stub
int[][] key2 = new int[key.length][key[0].length];
key2 = getReverseMartrix(key);
System.out.println("加密密钥逆矩阵为:");
showMartrix(key2);
return getDecrypttext(key2, ciphertext);
} private String getDecrypttext(int[][] key2, String ciphertext) {
// TODO Auto-generated method stub
int temp1, temp2, temp3;
StringBuilder plainttext = new StringBuilder();
for(int i=0; i<ciphertext.length(); i+=3) {
temp1 = key2[0][0]*(ciphertext.charAt(i) - 'A')
+ key2[0][1]*(ciphertext.charAt(i+1) - 'A')
+ key2[0][2]*(ciphertext.charAt(i+2) - 'A');
temp2 = key2[1][0]*(ciphertext.charAt(i) - 'A')
+ key2[1][1]*(ciphertext.charAt(i+1) - 'A')
+ key2[1][2]*(ciphertext.charAt(i+2) - 'A');
temp3 = key2[2][0]*(ciphertext.charAt(i) - 'A')
+ key2[2][1]*(ciphertext.charAt(i+1) - 'A')
+ key2[2][2]*(ciphertext.charAt(i+2) - 'A');
plainttext.append((char)('A'+temp1%26));
plainttext.append((char)('A'+temp2%26));
plainttext.append((char)('A'+temp3%26));
} return plainttext.toString();
} private void showMartrix(int[][] key2) {
for(int i=0; i<key2.length; i++) {
for(int j=0; j<key2[0].length; j++) {
System.out.print(key2[i][j]+ " ");
}
System.out.println();
}
} private int[][] getReverseMartrix(int[][] key2) {
// TODO Auto-generated method stub
int[][] key = new int[key2.length][key2[0].length];
for(int num=0; num<3; num++)
for(int i=0; i<26; i++)
for(int j=0; j<26; j++)
for(int k=0; k<26; k++) {
if((i*17+j*21+k*2)%26 == temp[num%3]
&& ((i*17+j*18+k*2)%26 == temp[(num+2)%3])
&& ((i*5+j*21+k*19)%26 == temp[(num+1)%3])) {
key[num][0] = i;
key[num][1] = j;
key[num][2] = k;
}
}
return key;
} private String getEncrypttext(String plainttext) {
// TODO Auto-generated method stub
int temp1 = 0, temp2, temp3;
StringBuilder cipertext = new StringBuilder();
for(int i=0; i<plainttext.length(); i+=3) {
temp1 = key[0][0]*(plainttext.charAt(i) - 'A')
+ key[0][1]*(plainttext.charAt(i+1) - 'A')
+ key[0][2]*(plainttext.charAt(i+2) - 'A');
temp2 = key[1][0]*(plainttext.charAt(i) - 'A')
+ key[1][1]*(plainttext.charAt(i+1) - 'A')
+ key[1][2]*(plainttext.charAt(i+2) - 'A');
temp3 = key[2][0]*(plainttext.charAt(i) - 'A')
+ key[2][1]*(plainttext.charAt(i+1) - 'A')
+ key[2][2]*(plainttext.charAt(i+2) - 'A');
cipertext.append((char)('A'+temp1%26));
cipertext.append((char)('A'+temp2%26));
cipertext.append((char)('A'+temp3%26));
} return cipertext.toString();
} }

结果截图:



实验总结

本次实验让我了解了代码规范性的重要性,同时结对编程也是我们小组合作得更加默契,对我们受益匪浅

20165323 实验三 敏捷开发与XP实践的更多相关文章

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

    20145213<Java程序设计>实验三敏捷开发与XP实践 实验要求 1.XP基础 2.XP核心实践 3.相关工具 实验内容 1.敏捷开发与XP 软件工程是把系统的.有序的.可量化的方法 ...

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

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

  3. JAVA课程实验报告 实验三 敏捷开发与XP实践

    北京电子科技学院(BESTI) 实     验    报     告 课程:Java程序设计  班级:1353  姓名:韩玉琪  学号:20135317 成绩:             指导教师:娄嘉 ...

  4. 20145225《Java程序设计》 实验三 "敏捷开发与XP实践"

    20145225<Java程序设计> 实验三 "敏捷开发与XP实践" 实验报告 实验内容 使用 git 上传代码 使用 git 相互更改代码 实现代码的重载 git 上 ...

  5. 20145215实验三 敏捷开发与XP实践

    20145215实验三 敏捷开发与XP实践 实验内容 XP基础 XP核心实践 相关工具 实验步骤 (一)敏捷开发与XP 软件工程是把系统的.有序的.可量化的方法应用到软件的开发.运营和维护上的过程.软 ...

  6. 20145325张梓靖 实验三 "敏捷开发与XP实践"

    20145325张梓靖 实验三 "敏捷开发与XP实践" 程序设计过程 实验内容 使用 git 上传代码 git上传中遇到的问题 使用 git 相互更改代码 实现代码的重构 git ...

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

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

  8. 2018-2019-20175205 实验三敏捷开发与XP实践《Java开发环境的熟悉》实验报告

    2018-2019-20175205 实验三敏捷开发与XP实践<Java开发环境的熟悉>实验报告 实验要求 没有Linux基础的同学建议先学习<Linux基础入门(新版)>&l ...

  9. 20175314 实验三 敏捷开发与XP实践

    20175314 实验二 Java面向对象程序设计 一.实验内容 XP基础 XP核心实践 相关工具 二.实验步骤 (一)代码格式化 创建"175314.exp3"项目,在该项目下创 ...

随机推荐

  1. 建立Oracle GoldenGate凭证

    了解如何为与数据库交互的流程创建数据库用户,分配正确的权限并防止未经授权使用凭据. 主题: 为Oracle GoldenGate分配凭证 保护Oracle GoldenGate凭证 3.1 为Orac ...

  2. roslaunch & gdb 调试指南(待补充)

    1. 安装xterm sudo apt-get install xterm 2. 在launch文件中添加如下内容: <node name="navigation" pkg= ...

  3. 【leetcode】557. Reverse Words in a String III

    Algorithm [leetcode]557. Reverse Words in a String III https://leetcode.com/problems/reverse-words-i ...

  4. 【转】Python标准模块--importlib

    [转]Python标准模块--importlib 作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 1 模块简介 P ...

  5. 判断HDFS文件是否存在

    hadoop判断文件是否存在 在shell中判断一个HDFS目录/文件是否存在 直接看shell代码: hadoop fs -test -e /hdfs_dirif [ $? -ne 0 ]; the ...

  6. eMMC基础技术3:eMMC总线token

    1.前言 本文主要介绍eMMC 总线协议相关的内容,主要包括: (1)command token format (2)response token format (3)data packet form ...

  7. lnmp 搭建 初试

    #初始化环境检查 # uname -r -.el6.x86_64 # uname -m x86_64 #添加mysql用户 useradd -s /sbin/nologin mysql -M #下载安 ...

  8. Linux内核之内存管理

    Linux内核之内存管理 Linux利用的是分段+分页单元把逻辑地址转换为物理地址; RAM的某些部分永久地分配给内核, 并用来存放内核代码以及静态内核数据结构; RAM的其余部分称动态内存(dyna ...

  9. jQuery.extend()参数

    非原创,转载仅供学习 在处理插件参数的接收上,通常使用jQuery的extend方法.extend方法传递单个对象的情况下,这个对象会合并到jQuery身上,而当用extend方法传递一个以上的参数时 ...

  10. Openssl与私有CA搭建

    转自:http://www.tuicool.com/articles/aURnim 随着网络技术的发展.internet的全球化,信息共享程度被进一步提高,各种基于互联网的应用如电子政务.电子商务日益 ...