實驗五

starming發表於2024-12-09

學號20145332 《Java程式設計》實驗五

實驗內容

TCP程式碼的結對完成,一人伺服器,一人客戶端。

結對隊友:20145313張雪純http://www.cnblogs.com/entropy/

伺服器程式碼:

import java.net.*;

import java.io.*;

import java.security.*;

import java.security.spec.*;

import javax.crypto.*;

import javax.crypto.spec.*;

import javax.crypto.interfaces.*;

import java.security.interfaces.*;

import java.math.*;

public class Server{

public static void main(String srgs[]) throws Exception {

    ServerSocket sc = null;

    Socket socket=null;

    try {

        sc= new ServerSocket(4421);//建立伺服器套接字

        System.out.println("埠號:" + sc.getLocalPort());

        System.out.println("伺服器已經啟動...");

        socket = sc.accept();   //等待客戶端連線

        System.out.println("已經建立連線");

        //獲得網路輸入流物件的引用

        BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));

        ////獲得網路輸出流物件的引用

        PrintWriter out=new PrintWriter(new BufferedWriter(new OutputStreamWriter(socket.getOutputStream())),true);



        //解密模組,最後的keykb即明文;使用Dec_RSA程式碼

        String aline2=in.readLine();

        BigInteger c=new BigInteger(aline2);

        FileInputStream f=new FileInputStream("Skey_RSA_priv.dat");

        ObjectInputStream b=new ObjectInputStream(f);

        RSAPrivateKey prk=(RSAPrivateKey)b.readObject( );

        BigInteger d=prk.getPrivateExponent();

        BigInteger n=prk.getModulus();

        //System.out.println("d= "+d);

        //System.out.println("n= "+n);

        BigInteger m=c.modPow(d,n);

        //System.out.println("m= "+m);

        byte[] keykb=m.toByteArray();

        //String aline3=new String(mt,"UTF8");

        //String aline3=parseByte2HexStr(byte buf[]);



        //源自SDec程式碼,用於解密

        String aline=in.readLine();//讀取客戶端傳送來的資料

        //FileInputStream  f2=new FileInputStream("keykb1.dat");

        //int num2=f2.available();

        //byte[] keykb=new byte[num2];

        //f2.read(keykb);

        byte[] ctext=parseHexStr2Byte(aline);

        Key k=new  SecretKeySpec(keykb,"DESede");

        Cipher cp=Cipher.getInstance("DESede");

        cp.init(Cipher.DECRYPT_MODE, k);

        byte []ptext=cp.doFinal(ctext);



        String p=new String(ptext,"UTF8");

        System.out.println("從客戶端接收到資訊為:"+p); //通過網路輸出流返回結果給客戶端



                               /*String aline2=in.readLine();

                               BigInteger c=new BigInteger(aline2);

                               FileInputStream f=new FileInputStream("Skey_RSA_priv.dat");

                               ObjectInputStream b=new ObjectInputStream(f);

                               RSAPrivateKey prk=(RSAPrivateKey)b.readObject( );

                               BigInteger d=prk.getPrivateExponent();

                               BigInteger n=prk.getModulus();

                               //System.out.println("d= "+d);

                               //System.out.println("n= "+n);

                               BigInteger m=c.modPow(d,n);

                               //System.out.println("m= "+m);

                               byte[] mt=m.toByteArray();

                               //String aline3=new String(mt,"UTF8");*/



        //程式碼源自DigestCalc,用於檢驗資訊完整性

        String aline3=in.readLine();

        String x=p;

        MessageDigest m2=MessageDigest.getInstance("MD5");

        m2.update(x.getBytes( ));

        byte a[ ]=m2.digest( );

        String result="";

        for (int i=0; i<a.length; i++){

            result+=Integer.toHexString((0x000000ff & a[i]) |

                    0xffffff00).substring(6);

        }

        System.out.println(result);



        //輸出結果

        if(aline3.equals(result)){

            System.out.println("匹配成功");

        }



        out.println("匹配成功");

        out.close();

        in.close();

        sc.close();

    } catch (Exception e) {

        System.out.println(e);

    }

}

public static String parseByte2HexStr(byte buf[]) {

    StringBuffer sb = new StringBuffer();

    for (int i = 0; i < buf.length; i++) {

        String hex = Integer.toHexString(buf[i] & 0xFF);

        if (hex.length() == 1) {

            hex = '0' + hex;

        }

        sb.append(hex.toUpperCase());

    }

    return sb.toString();

}

public static byte[] parseHexStr2Byte(String hexStr) {

    if (hexStr.length() < 1)

        return null;

    byte[] result = new byte[hexStr.length()/2];

    for (int i = 0;i< hexStr.length()/2; i++) {

        int high = Integer.parseInt(hexStr.substring(i*2, i*2+1 ), 16);

        int low = Integer.parseInt(hexStr.substring(i*2+1, i*2+2), 16);

        result[i] = (byte) (high * 16 + low);

    }

    return result;

}

}

結果截圖:
實驗五

相關文章