- 浏览: 6779 次
- 性别:
- 来自: 珠海
最近访客 更多访客>>
最新评论
-
jxj0401:
private static void breakDown(l ...
从控制台输入一串数字,将他们分成一个一个的输出
网络人远程控制软件是一款专业的远程桌面连接软件,专门针对企事业机关单位进行远程桌面连接设计。安装只需几秒、操作简单方便。完美的界面设计、强大的监控功能、稳定的系统平台,满足了客户实现远程桌面连接的需求。为用户远程办公、监控、远程协助提供了方便。
网络人远程桌面连接在很大程度上让客户领略了前所未有的监控感。网络人是国内远程桌面连接的领先人物,是国内唯一一位获得国家公安部产品安全监测报告的,继而奠定了在行业的地位。网络人相继开发出满足不同客户需求的远程桌面连接软件,产品多样化填补了远程控制软件行业的缺陷。
远程桌面连接可以操作被控端电脑收发邮件、查看报表、进行用户管理、系统维护更新、安装卸载软件等等, 就像直接在这台电脑操作一样方便。网络人远程控制企业版是一款使用UDP协议的内网穿透技术,可以穿透防火墙,不用做端口映射,不会被杀毒软件当作病毒来查杀,安全可靠。可实现的功能有:遥控鼠标键盘,进行远程桌面连接,批量分发文件,批量开机、关机,发送文字广播,远程开启摄像头形成视频墙,还能进行监控录像,以备定时查看,还有语音文字聊天功能,管理远程电脑进程和窗口,键盘记录读取,无需逐一输入IP/ID和控制密码被控电脑即可自动上线。网络人还可以选择U盾加密技术实现U盾加密保护,即使网络人控制软件账号密码不幸被盗,仍能确保公司安全不外泄,将企业信息安全提升到网络电子银行的安全标准,这样能让电脑监控功能的安全级别更加提高,就满足那些要求电脑桌面监控安全级别要求非常高的用户。
网络人远程桌面连接软件可实现用户对远程控制连接被控电脑桌面的需求,特别适用于其他方式的远程桌面连接不上时候,只需要登录到网络人官方网站下载,在双方电脑安装上网络人远程监控软件远程桌面连接软件,只需要双方电脑能上网,即可进行连接。这就有效解决了远程桌面连接不上问题。桌面连不上有可能是两个原因,开着防火墙、某个软件占用了某个网络端口,基于以上两点分析,网络人远程桌面连接软件可以提供另一种方式的远程桌面连接。
package cjl.server;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
/**
* 远程控制服务端
*
* @author kowloon
*
*/
public class MyServer {
public static void main(String[] args) throws IOException {
new MyServer().initServer();
}
// 初始化服务端的方法
public void initServer() throws IOException {
// 创建服务端套接字对象
ServerSocket server = new ServerSocket(10010);
System.out.println("服务器已经启动,等待连接");
// 等待客户端连接,如果有客户端连接上,会收到客户端套接字
Socket socket = server.accept();
System.out.println("一个客户端连上了"+socket.getRemoteSocketAddress());
// 启动一个线程来给客户端发送服务端桌面
SendThread st = new SendThread(socket);
st.start();
//启动一个线程来接收客户端发来的控制消息
RecieveThread rt = new RecieveThread(socket);
rt.start();
}
}
package cjl.server;
import java.awt.Robot;
import java.awt.event.InputEvent;
import java.awt.event.MouseEvent;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.net.Socket;
/**
* 服务端用来接收客户端消息的线程
*
* @author kowloon
*
*/
public class RecieveThread extends Thread {
Socket socket;
public RecieveThread(Socket socket) {
this.socket = socket;
}
public void run() {
try {
Robot robot = new Robot();
InputStream ips = socket.getInputStream();
// 接收的是对象流的消息,包装成对象输入流
ObjectInputStream ois = new ObjectInputStream(ips);
while (true) {
// 收和发的顺序要一致
int x = ois.readInt();
int y = ois.readInt();
int btnNum = ois.readInt();
String type = (String) ois.readObject();
int btnMask = InputEvent.BUTTON1_MASK;
if (btnNum == MouseEvent.BUTTON1) {
btnMask = InputEvent.BUTTON1_MASK;
} else if (btnNum == MouseEvent.BUTTON2) {
btnMask = InputEvent.BUTTON2_MASK;
} else if (btnNum == MouseEvent.BUTTON3) {
btnMask = InputEvent.BUTTON3_MASK;
}
if ("pressed".equals(type)) {
// 移送光标到xy
robot.mouseMove(x, y);
robot.mousePress(btnMask);// 按下对应的鼠标按键
} else if ("released".equals(type)) {
// 移送光标到xy
robot.mouseMove(x, y);
robot.mouseRelease(btnMask);
} else if ("moved".equals(type)) {
// 移送光标到xy
robot.mouseMove(x, y);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
package cjl.server;
import java.awt.Dimension;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.Toolkit;
import java.awt.image.BufferedImage;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.Socket;
import javax.swing.ImageIcon;
/**
* 发送数据的线程
*
* @author kowloon
*
*/
public class SendThread extends Thread {
Socket socket;
public SendThread(Socket socket) {
this.socket = socket;
}
public void run() {
try {
//从套接字上获得输出流
OutputStream ops = socket.getOutputStream();
//包装成对象流
ObjectOutputStream oos = new ObjectOutputStream(ops);
// 创建一个机器人对象,用来截屏
Robot robot = new Robot();
while (true) {
// 获得屏幕的分辨率
Toolkit tool = Toolkit.getDefaultToolkit();
Dimension dim = tool.getScreenSize();
// 要截取的起始点
Point p = new Point(0, 0);
// 指定截取的区域
Rectangle rect = new Rectangle(p, dim);
// 开始截屏,获得截取到的图像
BufferedImage img = robot.createScreenCapture(rect);
//由于BufferedImage没有实现序列化,不能写到IO中
//将BufferedImage包装成可写入IO的图像对象
ImageIcon icon = new ImageIcon(img);
//写出对象
oos.writeObject(icon);
oos.flush();
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
} catch (Exception e1) {
e1.printStackTrace();
}
}
}
package 远程控制客户端;
import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.awt.event.MouseMotionListener;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.Socket;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextField;
/**
* 远程控制客户端
*
* @author kowloon
*
*/
public class ClientUI extends JFrame {
ObjectOutputStream oos;
public static void main(String[] args) {
new ClientUI().initUI();
}
private JTextField ipField;
private JTextField portField;
private JPanel panel;
/**
* 初始化客户端界面的方法
*/
public void initUI() {
this.setTitle("远程控制");
this.setSize(800, 600);
this.setResizable(false);
this.setDefaultCloseOperation(3);
// this.setLayout(new BorderLayout());
// 用来显示远程桌面的面板
panel = new JPanel();
JScrollPane jsp = new JScrollPane(panel);
jsp.setPreferredSize(new Dimension(600, 400));
jsp.setAutoscrolls(true);
this.add(jsp, BorderLayout.CENTER);
JPanel tool = new JPanel();
tool.setPreferredSize(new Dimension(600, 50));
this.add(tool, BorderLayout.SOUTH);
JLabel ipLabel = new JLabel("IP:");
ipField = new JTextField("127.0.0.1", 10);
JLabel portLabel = new JLabel("PORT:");
portField = new JTextField("10010",;
JButton btn = new JButton("连接服务器");
tool.add(ipLabel);
tool.add(ipField);
tool.add(portLabel);
tool.add(portField);
tool.add(btn);
this.setVisible(true);
// 给按钮添加监听器
MyListener mlis = new MyListener();
btn.addActionListener(mlis);
// 给面板添加监听器
MyMouseListener mmlis = new MyMouseListener();
panel.addMouseListener(mmlis);
panel.addMouseMotionListener(mmlis);
}
// panel的鼠标监听器
class MyMouseListener implements MouseListener, MouseMotionListener {
@Override
public void mousePressed(MouseEvent e) {
// 得到鼠标的位置
int x = e.getX();
int y = e.getY();
// 得到按下的是哪一个键
int btnNum = e.getButton();
String type = "pressed";
if (oos != null) {
try {
oos.writeInt(x);
oos.writeInt(y);
oos.writeInt(btnNum);
oos.writeObject(type);
oos.flush();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
@Override
public void mouseReleased(MouseEvent e) {
int x = e.getX();
int y = e.getY();
// 得到按下的是哪一个键
int btnNum = e.getButton();
String type = "released";
if (oos != null) {
try {
oos.writeInt(x);
oos.writeInt(y);
oos.writeInt(btnNum);
oos.writeObject(type);
oos.flush();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
public void mouseDragged(MouseEvent e) {
}
public void mouseMoved(MouseEvent e) {
int x = e.getX();
int y = e.getY();
// 得到按下的是哪一个键
int btnNum = e.getButton();
String type = "moved";
if (oos != null) {
try {
oos.writeInt(x);
oos.writeInt(y);
oos.writeInt(btnNum);
oos.writeObject(type);
oos.flush();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
@Override
public void mouseEntered(MouseEvent e) {
// TODO Auto-generated method stub
}
@Override
public void mouseExited(MouseEvent e) {
// TODO Auto-generated method stub
}
@Override
public void mouseClicked(MouseEvent e) {
// TODO Auto-generated method stub
}
}
// 按钮监听器
class MyListener implements ActionListener {
@Override
public void actionPerformed(ActionEvent e) {
// 获得Ip@端口
String ip = ipField.getText();
String port = portField.getText();
int intPort = Integer.parseInt(port);
try {
// 创建客户端套接字,连接服务端
Socket socket = new Socket(ip, intPort);
OutputStream ops = socket.getOutputStream();
// 需要发送int,String,要包装成对象流
oos = new ObjectOutputStream(ops);
// 不停的接受服务端发来的图片
RecieveThread rt = new RecieveThread(socket, panel);
rt.start();
} catch (Exception e1) {
// 弹出错误提示框
JOptionPane.showMessageDialog(null, "网络异常,无法连接服务器!");
e1.printStackTrace();
}
}
}
}
package 远程控制客户端;
import java.awt.Dimension;
import java.awt.Graphics;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.net.Socket;
import javax.swing.ImageIcon;
import javax.swing.JPanel;
/**
* 客户端接收服务端桌面的线程
*
* @author kowloon
*
*/
public class RecieveThread extends Thread {
Socket socket;
JPanel panel;
public RecieveThread(Socket socket, JPanel panel) {
this.socket = socket;
this.panel = panel;
}
public void run() {
try {
// 从Socket上获得输入流
InputStream ips = socket.getInputStream();
// 由于接受的是对象流
ObjectInputStream ois = new ObjectInputStream(ips);
while (true) {
// 读取对象,由于发送的是ImageIcon,这里可以强制转型成ImageIcon
Object obj = ois.readObject();
ImageIcon icon = (ImageIcon) obj;
//获得图像大小(即为服务端桌面大小)
int width = icon.getIconWidth();
int height = icon.getIconHeight();
System.out.println(width+"<>"+height);
//修改panel大小为服务端桌面大小
panel.setPreferredSize(new Dimension(width,height));
//获得画布
Graphics g = panel.getGraphics();
g.drawImage(icon.getImage(), 0,0, null);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
网络人远程桌面连接在很大程度上让客户领略了前所未有的监控感。网络人是国内远程桌面连接的领先人物,是国内唯一一位获得国家公安部产品安全监测报告的,继而奠定了在行业的地位。网络人相继开发出满足不同客户需求的远程桌面连接软件,产品多样化填补了远程控制软件行业的缺陷。
远程桌面连接可以操作被控端电脑收发邮件、查看报表、进行用户管理、系统维护更新、安装卸载软件等等, 就像直接在这台电脑操作一样方便。网络人远程控制企业版是一款使用UDP协议的内网穿透技术,可以穿透防火墙,不用做端口映射,不会被杀毒软件当作病毒来查杀,安全可靠。可实现的功能有:遥控鼠标键盘,进行远程桌面连接,批量分发文件,批量开机、关机,发送文字广播,远程开启摄像头形成视频墙,还能进行监控录像,以备定时查看,还有语音文字聊天功能,管理远程电脑进程和窗口,键盘记录读取,无需逐一输入IP/ID和控制密码被控电脑即可自动上线。网络人还可以选择U盾加密技术实现U盾加密保护,即使网络人控制软件账号密码不幸被盗,仍能确保公司安全不外泄,将企业信息安全提升到网络电子银行的安全标准,这样能让电脑监控功能的安全级别更加提高,就满足那些要求电脑桌面监控安全级别要求非常高的用户。
网络人远程桌面连接软件可实现用户对远程控制连接被控电脑桌面的需求,特别适用于其他方式的远程桌面连接不上时候,只需要登录到网络人官方网站下载,在双方电脑安装上网络人远程监控软件远程桌面连接软件,只需要双方电脑能上网,即可进行连接。这就有效解决了远程桌面连接不上问题。桌面连不上有可能是两个原因,开着防火墙、某个软件占用了某个网络端口,基于以上两点分析,网络人远程桌面连接软件可以提供另一种方式的远程桌面连接。
package cjl.server;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
/**
* 远程控制服务端
*
* @author kowloon
*
*/
public class MyServer {
public static void main(String[] args) throws IOException {
new MyServer().initServer();
}
// 初始化服务端的方法
public void initServer() throws IOException {
// 创建服务端套接字对象
ServerSocket server = new ServerSocket(10010);
System.out.println("服务器已经启动,等待连接");
// 等待客户端连接,如果有客户端连接上,会收到客户端套接字
Socket socket = server.accept();
System.out.println("一个客户端连上了"+socket.getRemoteSocketAddress());
// 启动一个线程来给客户端发送服务端桌面
SendThread st = new SendThread(socket);
st.start();
//启动一个线程来接收客户端发来的控制消息
RecieveThread rt = new RecieveThread(socket);
rt.start();
}
}
package cjl.server;
import java.awt.Robot;
import java.awt.event.InputEvent;
import java.awt.event.MouseEvent;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.net.Socket;
/**
* 服务端用来接收客户端消息的线程
*
* @author kowloon
*
*/
public class RecieveThread extends Thread {
Socket socket;
public RecieveThread(Socket socket) {
this.socket = socket;
}
public void run() {
try {
Robot robot = new Robot();
InputStream ips = socket.getInputStream();
// 接收的是对象流的消息,包装成对象输入流
ObjectInputStream ois = new ObjectInputStream(ips);
while (true) {
// 收和发的顺序要一致
int x = ois.readInt();
int y = ois.readInt();
int btnNum = ois.readInt();
String type = (String) ois.readObject();
int btnMask = InputEvent.BUTTON1_MASK;
if (btnNum == MouseEvent.BUTTON1) {
btnMask = InputEvent.BUTTON1_MASK;
} else if (btnNum == MouseEvent.BUTTON2) {
btnMask = InputEvent.BUTTON2_MASK;
} else if (btnNum == MouseEvent.BUTTON3) {
btnMask = InputEvent.BUTTON3_MASK;
}
if ("pressed".equals(type)) {
// 移送光标到xy
robot.mouseMove(x, y);
robot.mousePress(btnMask);// 按下对应的鼠标按键
} else if ("released".equals(type)) {
// 移送光标到xy
robot.mouseMove(x, y);
robot.mouseRelease(btnMask);
} else if ("moved".equals(type)) {
// 移送光标到xy
robot.mouseMove(x, y);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
package cjl.server;
import java.awt.Dimension;
import java.awt.Point;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.Toolkit;
import java.awt.image.BufferedImage;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.Socket;
import javax.swing.ImageIcon;
/**
* 发送数据的线程
*
* @author kowloon
*
*/
public class SendThread extends Thread {
Socket socket;
public SendThread(Socket socket) {
this.socket = socket;
}
public void run() {
try {
//从套接字上获得输出流
OutputStream ops = socket.getOutputStream();
//包装成对象流
ObjectOutputStream oos = new ObjectOutputStream(ops);
// 创建一个机器人对象,用来截屏
Robot robot = new Robot();
while (true) {
// 获得屏幕的分辨率
Toolkit tool = Toolkit.getDefaultToolkit();
Dimension dim = tool.getScreenSize();
// 要截取的起始点
Point p = new Point(0, 0);
// 指定截取的区域
Rectangle rect = new Rectangle(p, dim);
// 开始截屏,获得截取到的图像
BufferedImage img = robot.createScreenCapture(rect);
//由于BufferedImage没有实现序列化,不能写到IO中
//将BufferedImage包装成可写入IO的图像对象
ImageIcon icon = new ImageIcon(img);
//写出对象
oos.writeObject(icon);
oos.flush();
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
} catch (Exception e1) {
e1.printStackTrace();
}
}
}
package 远程控制客户端;
import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.awt.event.MouseMotionListener;
import java.io.IOException;
import java.io.ObjectOutputStream;
import java.io.OutputStream;
import java.net.Socket;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextField;
/**
* 远程控制客户端
*
* @author kowloon
*
*/
public class ClientUI extends JFrame {
ObjectOutputStream oos;
public static void main(String[] args) {
new ClientUI().initUI();
}
private JTextField ipField;
private JTextField portField;
private JPanel panel;
/**
* 初始化客户端界面的方法
*/
public void initUI() {
this.setTitle("远程控制");
this.setSize(800, 600);
this.setResizable(false);
this.setDefaultCloseOperation(3);
// this.setLayout(new BorderLayout());
// 用来显示远程桌面的面板
panel = new JPanel();
JScrollPane jsp = new JScrollPane(panel);
jsp.setPreferredSize(new Dimension(600, 400));
jsp.setAutoscrolls(true);
this.add(jsp, BorderLayout.CENTER);
JPanel tool = new JPanel();
tool.setPreferredSize(new Dimension(600, 50));
this.add(tool, BorderLayout.SOUTH);
JLabel ipLabel = new JLabel("IP:");
ipField = new JTextField("127.0.0.1", 10);
JLabel portLabel = new JLabel("PORT:");
portField = new JTextField("10010",;
JButton btn = new JButton("连接服务器");
tool.add(ipLabel);
tool.add(ipField);
tool.add(portLabel);
tool.add(portField);
tool.add(btn);
this.setVisible(true);
// 给按钮添加监听器
MyListener mlis = new MyListener();
btn.addActionListener(mlis);
// 给面板添加监听器
MyMouseListener mmlis = new MyMouseListener();
panel.addMouseListener(mmlis);
panel.addMouseMotionListener(mmlis);
}
// panel的鼠标监听器
class MyMouseListener implements MouseListener, MouseMotionListener {
@Override
public void mousePressed(MouseEvent e) {
// 得到鼠标的位置
int x = e.getX();
int y = e.getY();
// 得到按下的是哪一个键
int btnNum = e.getButton();
String type = "pressed";
if (oos != null) {
try {
oos.writeInt(x);
oos.writeInt(y);
oos.writeInt(btnNum);
oos.writeObject(type);
oos.flush();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
@Override
public void mouseReleased(MouseEvent e) {
int x = e.getX();
int y = e.getY();
// 得到按下的是哪一个键
int btnNum = e.getButton();
String type = "released";
if (oos != null) {
try {
oos.writeInt(x);
oos.writeInt(y);
oos.writeInt(btnNum);
oos.writeObject(type);
oos.flush();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
public void mouseDragged(MouseEvent e) {
}
public void mouseMoved(MouseEvent e) {
int x = e.getX();
int y = e.getY();
// 得到按下的是哪一个键
int btnNum = e.getButton();
String type = "moved";
if (oos != null) {
try {
oos.writeInt(x);
oos.writeInt(y);
oos.writeInt(btnNum);
oos.writeObject(type);
oos.flush();
} catch (IOException e1) {
e1.printStackTrace();
}
}
}
@Override
public void mouseEntered(MouseEvent e) {
// TODO Auto-generated method stub
}
@Override
public void mouseExited(MouseEvent e) {
// TODO Auto-generated method stub
}
@Override
public void mouseClicked(MouseEvent e) {
// TODO Auto-generated method stub
}
}
// 按钮监听器
class MyListener implements ActionListener {
@Override
public void actionPerformed(ActionEvent e) {
// 获得Ip@端口
String ip = ipField.getText();
String port = portField.getText();
int intPort = Integer.parseInt(port);
try {
// 创建客户端套接字,连接服务端
Socket socket = new Socket(ip, intPort);
OutputStream ops = socket.getOutputStream();
// 需要发送int,String,要包装成对象流
oos = new ObjectOutputStream(ops);
// 不停的接受服务端发来的图片
RecieveThread rt = new RecieveThread(socket, panel);
rt.start();
} catch (Exception e1) {
// 弹出错误提示框
JOptionPane.showMessageDialog(null, "网络异常,无法连接服务器!");
e1.printStackTrace();
}
}
}
}
package 远程控制客户端;
import java.awt.Dimension;
import java.awt.Graphics;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.net.Socket;
import javax.swing.ImageIcon;
import javax.swing.JPanel;
/**
* 客户端接收服务端桌面的线程
*
* @author kowloon
*
*/
public class RecieveThread extends Thread {
Socket socket;
JPanel panel;
public RecieveThread(Socket socket, JPanel panel) {
this.socket = socket;
this.panel = panel;
}
public void run() {
try {
// 从Socket上获得输入流
InputStream ips = socket.getInputStream();
// 由于接受的是对象流
ObjectInputStream ois = new ObjectInputStream(ips);
while (true) {
// 读取对象,由于发送的是ImageIcon,这里可以强制转型成ImageIcon
Object obj = ois.readObject();
ImageIcon icon = (ImageIcon) obj;
//获得图像大小(即为服务端桌面大小)
int width = icon.getIconWidth();
int height = icon.getIconHeight();
System.out.println(width+"<>"+height);
//修改panel大小为服务端桌面大小
panel.setPreferredSize(new Dimension(width,height));
//获得画布
Graphics g = panel.getGraphics();
g.drawImage(icon.getImage(), 0,0, null);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
相关推荐
远程桌面连接(Remote Desktop Connection,RDC)是微软提供的功能,允许用户通过网络访问并控制另一台计算机的桌面环境。在C#中,我们可以利用Microsoft Terminal Services API(现在称为Remote Desktop Services ...
易语言远程桌面连接源码是基于易语言编程环境开发的一款应用程序,主要功能是实现远程桌面控制,让用户能够通过网络访问并操作远程计算机。这个压缩包包含以下三个关键文件: 1. **mstsc.e**:这是易语言编译后的...
在Windows操作系统中,远程桌面连接(Remote Desktop Connection,也称为mstsc)是用户通过网络访问其他计算机桌面环境的重要工具。然而,随着频繁的使用,远程桌面连接会留下历史记录,包括连接过的计算机名、...
首先,远程桌面连接是Windows操作系统提供的一种功能,允许用户通过网络访问并控制另一台计算机的桌面环境。在Java中,我们不能直接调用RDP的功能,因为Java标准库并不包含直接操作RDP的API。但我们可以借助于操作...
- 在使用远程桌面连接或Telnet时,请确保网络安全。特别是Telnet使用明文传输数据,容易被窃听,因此不建议在不安全的网络环境中使用。 - 对于远程桌面连接,建议使用更安全的协议,如RDP加密,以及设置复杂的密码和...
**WPF 远程桌面连接详解** 在Windows Presentation Foundation(WPF)中实现远程桌面连接功能,可以让用户通过应用程序远程操控另一台计算机。这在分布式系统、远程办公或技术支持等场景下非常有用。WPF提供了丰富...
Java远程桌面连接是一种技术,允许用户通过网络访问和控制远程计算机的桌面环境,类似于Windows操作系统中的Remote Desktop Protocol (RDP)。在Java中,我们通常使用Java Remote Method Invocation (Java RMI) 或 ...
Windows 7 远程桌面连接设置教程 Windows 7 远程桌面连接设置是指通过 Windows 7 操作系统连接到其他计算机的远程桌面,以便于远程控制、文件传输、剪贴板数据交互等操作的设置过程。下面是 Windows 7 远程桌面连接...
远程桌面连接软件是一种高效便捷的工具,允许用户通过网络访问并控制远程计算机,如同亲自坐在那台电脑前操作一样。这种技术在IT行业中被广泛应用,无论是进行远程技术支持、多地点协作还是个人工作需求,都能发挥...
WIN7远程桌面连接方法 WIN7远程桌面连接方法是指用户可以通过远程桌面连接到另一台计算机,访问和控制该计算机的桌面。该方法可以让用户在任何位置,通过任何连接来访问和控制Windows XP Professional的计算机。 ...
远程桌面连接是Windows操作系统提供的一种服务,允许用户通过网络访问并控制远程计算机。当遇到“远程桌面连接已断开”这样的问题时,通常意味着在尝试建立或维持远程会话时遇到了障碍。这个问题可能由多种因素引起...
远程桌面连接工具是Windows操作系统中一个非常重要的功能,它允许用户通过网络访问并控制其他计算机,尤其是对于系统管理员和IT专业人员来说,这种工具在管理远程服务器或工作站时显得尤为重要。"windos服务器远程...
"Windows Server 2008修改远程桌面连接数" Windows Server 2008 是微软公司推出的服务器操作系统,具有强大的功能和高效的性能。在服务器上,远程桌面连接是非常常用的功能,允许用户远程登录服务器,进行文件管理...
Windows 系统远程桌面连接 Windows 系统远程桌面连接是指通过远程桌面连接协议(RDP)连接到远程 Windows 计算机的桌面环境,从而实现远程控制和管理计算机。下面是 Windows 系统远程桌面连接的详细知识点: 1. ...
在IT领域,远程桌面连接是一种常见的技术支持手段,它允许用户通过网络从一个设备控制另一个设备的桌面环境。对于那些使用Windows 2000以前版本的系统用户来说,由于这些系统并未内置远程桌面连接功能,因此需要借助...
【MAC版远程桌面连接】 在数字化的工作环境中,跨平台协作变得越来越普遍,特别是在苹果Mac用户需要访问Windows系统资源时,远程桌面连接工具显得尤为重要。"MAC版远程桌面连接"正是一种解决方案,它允许用户通过...
标题中的“wince 实现远程桌面连接”指的是在Windows Embedded Compact (WinCE)操作系统上实现远程桌面功能,允许用户通过个人计算机(PC)访问并控制WinCE设备的桌面。这在设备调试、管理或者无显示器的场景下非常...
在IT领域,远程桌面连接是一种常见的技术,它允许用户通过网络访问并控制远程计算机的桌面环境。本篇文章将详细介绍如何在Windows操作系统与银河麒麟操作系统之间实现互相远程桌面连接。 银河麒麟,全称银河麒麟...
远程桌面连接是Windows操作系统中的一个核心功能,允许用户通过网络访问另一台计算机的桌面环境,进行远程控制和操作。在Windows XP系统中,这个功能已经存在,但随着系统的升级和优化,其功能得到了显著增强。标题...