//Udp实现消息的发送和接收

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetSocketAddress;
import java.net.SocketException;
import java.util.Scanner; public class UdpUtils implements Runnable { //定义Socket数据包服务
private DatagramSocket socket; public UdpUtils(int port) {
try {
//创建socket数据包服务
socket = new DatagramSocket();
} catch (SocketException e) {
e.printStackTrace();
}
} //发送
public void send(String content, String ip, int port) {
//获取接收端 的IP 和 端口号
InetSocketAddress address = new InetSocketAddress(ip, port);
//创建数据包 并将 消息内容 、地址 传入
DatagramPacket dp = new DatagramPacket(content.getBytes(),
content.getBytes().length,address);
try {
//发送数据包
socket.send(dp);
try {
Thread.sleep(1); //防止Udp传输时,包错误。
} catch (InterruptedException e) {
e.printStackTrace();
}
} catch (IOException e) {
e.printStackTrace();
}
} //接收
@Override
public void run() {
byte[] buf = new byte[1024];
//创建数据包 将 发送过来的 消息内容 取出
DatagramPacket dp = new DatagramPacket(buf, buf.length);
while (true) {
try {
//接收数据包
socket.receive(dp);
// System.out.println(new String(dp.getData(), 0, dp.getLength()));
} catch (IOException e) {
e.printStackTrace();
}
}
}
} //Test 测试
class TestUdpUtils{
public static void main(String[] args) {
UdpUtils utils = new UdpUtils(10010);
Thread thread = new Thread(utils);
thread.start();
Scanner input = new Scanner(System.in);
while(true){
String msg = input.next();
if(msg.equals("exit")){
input.close();
System.exit(0);
}
utils.send("Send:" + msg, "127.0.0.1", 10010);
}
}
}

//Udp实现图片的上传

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetSocketAddress;
import java.net.SocketException; public class UdpMapUtils implements Runnable { private DatagramSocket socket;
private File file;
private String ip;
private int port; public UdpMapUtils(File file, String ip, int port) {
this.file = file;
this.ip = ip;
this.port = port;
try {
socket = new DatagramSocket(port);
} catch (SocketException e) {
e.printStackTrace();
}
} public void send(File file) { InetSocketAddress address = new InetSocketAddress(ip, port);
// System.out.println(address);
BufferedInputStream bis = null;
try {
bis = new BufferedInputStream(new FileInputStream(file));
byte[] buf = new byte[1024];
while (bis.read(buf) != -1) {
DatagramPacket dp = new DatagramPacket(buf, buf.length, address);
socket.send(dp);
Thread.sleep(2);
}
byte[] b = "over".getBytes();
DatagramPacket dp = new DatagramPacket(b, b.length,address);
socket.send(dp);
} catch (Exception e) {
e.printStackTrace();
}
finally{
try {
bis.close();
} catch (IOException e) {
e.printStackTrace();
}
socket.close();
}
} @Override
public void run() { BufferedOutputStream bos = null; try {
bos = new BufferedOutputStream(new FileOutputStream(file));
byte[] buf = new byte[1024];
while (true) {
DatagramPacket dp = new DatagramPacket(buf, buf.length);
socket.receive(dp);
if(new String(buf,0,dp.getLength()).equals("over"))
break;
bos.write(buf);
bos.flush();
}
} catch (Exception e) {
e.printStackTrace();
}
finally {
try {
bos.close();
} catch (IOException e) {
e.printStackTrace();
}
socket.close();
}
}
}

Udp实现消息的发送和接收、以及图片的上传的更多相关文章

  1. 探索 OpenStack 之(15):oslo.messaging 和 Cinder 中 MessageQueue 消息的发送和接收

    前言:上一篇文章 只是 RabbitMQ 的科普,本文将仔细分析 Cinder 中 RabbitMQ 的各组件的使用.消息的发送和接收等.由于各流程步骤很多,本文只会使用若干流程图来加以阐述,尽量做到 ...

  2. Queue 消息的发送与接收(PTP 消息传递模型)

    上篇博客写到了JMS两种消息模型(P2P.pub/sub)<JMS两种消息模型>.本篇博客通过一个实例来进一步了解P2P模型. Queue消息的发送与接收--PTP消息传递模型,样例: Q ...

  3. 项目总结22:Java UDP Socket数据的发送和接收

    项目总结22:Java UDP Socket数据的发送和接收 1-先上demo 客户端(发送数据) package com.hs.pretest.udp; import java.io.IOExcep ...

  4. nodejs 数据库操作,消息的发送和接收,模拟同步

    var deasync = require('deasync'); //导入模板 var mysql=require('mysql'); var Stomp = require('stompjs'); ...

  5. msgrcv,msgsnd进程通信,消息的发送和接收

    //进程通信,消息的发送和接收 //client.c #include <unistd.h> #include <sys/types.h> #include <sys/s ...

  6. 【Spring Boot】Spring Boot之整合RabbitMQ并实现消息的发送和接收

    一.项目配置 1)引入maven坐标 <!--amqp--> <dependency> <groupId>org.springframework.boot</ ...

  7. 用PHP尝试RabbitMQ(amqp扩展)实现消息的发送和接收

    消费者:接收消息 逻辑:创建连接-->创建channel-->创建交换机-->创建队列-->绑定交换机/队列/路由键-->接收消息 <?php /********* ...

  8. 使用spring-rabbit测试RabbitMQ消息确认(发送确认,接收确认)

    1.首先是rabbitmq的配置文件: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns ...

  9. RabbitMQ消息确认(发送确认,接收确认)

    前面几篇记录了收发消息的demo,今天记录下关于 消息确认方面的 问题. 下面是几个问题: 1.为什么要进行消息确认? 2.rabbitmq消息确认 机制是什么样的? 3.发送方如何确认消息发送成功? ...

随机推荐

  1. ElasticSearch的Marvel更新license

    Marvel安装的时候需要申请一个license,否则只有30天的使用时间,到期后最多保存7天的监控数据,为了造成不必要的监控数据丢失,建议安装的同时注册一个lincense,方法如下: 1.     ...

  2. 简单VR照片 使用陀螺仪、姿态角(Roll、Pitch、Yaw )、四元数

        最近在做一个类似VR照片的demo,跟全景图片也很像,只是VR照片与全景720度显示,我只做了180度.但我发现他们实现的原理有一丝相似,希望可以给一些想入行AR.VR的朋友一些提示吧.   ...

  3. 数据库MySQL安装和校验

    1.安装MySQL 双击已经下载的安装包: Typical:典型安装,第一次安装建议选择该类安装 Custom:自定义安装,在对数据库熟悉后,知道自己需要哪些组件时,可以选择该类安装(这里选择的是自定 ...

  4. python中defaultdict的用法

    初识defaultdict 之前在使用字典的时候, 用的比较随意, 只是简单的使用dict. 然而这样在使用不存在的key的时候发生KeyError这样的一个报错, 这时候就该defaultdict登 ...

  5. canvas——路径搜索

    在前一篇博客中随机生成迷宫,现在就以随机生成的迷宫为地图,开始寻找路径. 迷宫寻路也可以使用DFS,BFS,但常见的是A*算法,它是启发式搜索算法的一种,效率相比前两者也更高.接下来以A*算法为例,迷 ...

  6. Mac下安装MySQL、Workbench以及建数据库建表最基础操作

    刚用上Mac,什么都不懂,加之以前还没有用过mysql,就想着在Mac上装一个mysql来自己玩,奈何,在网上找了大半天,没有一个干货!愤怒!下面是我安装的过程,希望能帮到和我情况差不多的朋友   首 ...

  7. RabbitMQ系列教程之三:发布/订阅(Publish/Subscribe)

    (本教程是使用Net客户端,也就是针对微软技术平台的)   在前一个教程中,我们创建了一个工作队列.工作队列背后的假设是每个任务会被交付给一个[工人].在这一部分我们将做一些完全不同的事情--我们将向 ...

  8. dubbo的简单应用

    一. dubbo简介 dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,是阿里巴巴SOA服务化治理方案的核心框架. 二. 架构 引用dubbo的架构图: Provide ...

  9. 自动清理SQLServerErrorLog错误日志避免太大

    问题描述:开启SQLServer自动备份后,备份文件越来越多,有没有及时清理,导致服务器空间不足,备份出错,以至于出现几个G的ErrorLog文件,影响系统的登录管理. 解决办法:定期清理SQLSer ...

  10. ELK-Kibana-01

      1.Kibana介绍   Kibana 是一个设计使用和Elasticsearch配置工作的开源分析和可视化平台.可以用它进行搜索.查看.集成Elasticsearch中的数据索引.可以利用各种图 ...