1、网络的大致结构

  

2、网络编程

通过直接或间接地使用网络通讯的协议实现计算机与计算机之间的通讯。在TCP/IP协议层主要麦网络主机的定位,数据传输的路由,由IP地址可以唯一地确定Internet上的一台机。

3、通过TCP/IP制作的网络应用软件的结构

(1)CS结构(Client---Service)

Client客户端------(TCP/IP协议)-------Service服务器端

  eg:QQ      王者荣耀游戏软件客户端

  优点:无需记网址

  缺点:需要安装客户端,占内存,安装过程繁琐,需要手动更新

(2)BS结构(Browser------Service)

Browser浏览器-------(http协议(TCP/IP协议的升级))-----Service服务器(web服务器)

  eg:百度

  优点:无需安装客户端,无需更新,直接从官网J进入

  缺点:要记网址

4、TCP和UDP的区别

TCP:可靠的传输协议,点对点的传输,类似于视频聊天,微信点对点的聊天。TCP传输的时候没有大小的限制。

UDP:不可靠的网络传输协议,类似于广播。使用UDP传输数据时有大小的限制,每个被传输 的数据必须限定在64kb之内。

5、基于URL的编程

URL(Uniform Resource Locator)---一一致资源定位器

表示Internet上某一资源的地址,通过URL可以访问Internet上的各种网络资源。

URL的写法:

协议的名称://资源的地址

http:不安全,无加密

https:安全,加密,涉及到支付功能都会用https

基于URL的java的网络编程:

java程序----(通过URL)------获取资源

java中对于网络编程的包在java.net中

分析:

    资源----------------(读取到)----------内存中

package URL;

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL; public class URLTest { public static void main(String[] args) {
//第一步,创建URL对象
try {
URL url=new URL("http://www.baidu.com/");
//把url指向的文件或数据转换成内存中的流
try {
InputStream inputStream=url.openStream();
//法1、用字节读取
/*byte[] bytes=new byte[inputStream.available()];
inputStream.read(bytes);
String str=new String(bytes);
System.out.println("读取的数据:"+str);
inputStream.close();*/ //法2、如果用BufferedReader读取
BufferedReader reader=new BufferedReader(new InputStreamReader(inputStream));
String content;
while((content=reader.readLine())!=null){
System.out.println(content);
}
reader.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } }

6、Socket的网络编程

(1)本质:基于TCP/IP协议的模型,实现的是网络的通讯

(2)服务器端的Socket----  ServerSocket

     客户端的Socket------Socket

     大致的实现步骤:

(a)创建Socket

(b)打开连接到Socket的输入/输出流

(c)按照一定的协议对Socket进行读/写的操作

(d)关闭Socket

package Socket;

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.DataInputStream;
import java.io.DataOutput;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Scanner; public class MyChatServer {
public static final String ADDRESS="127.0.0.1";
public static final int PORT=20019;
public static void main(String[] args) {
//第一步:构建Socket对象
try {
//监听的是本机上的端口号
ServerSocket serverSocket=new ServerSocket(PORT);
System.out.println("开始监听服务器发来的请求");
//表示监听的对象
Socket socket=serverSocket.accept();//线程阻塞的方法
//获取socket传过来的数据流
InputStream inputStream=socket.getInputStream();
//把数据打印出来
DataInputStream dataInput=new DataInputStream(inputStream) ;
String str;
System.out.println("从客户端传过来的数据");
while((str=dataInput.readUTF())!=null){
System.out.println(str);
}
System.out.println("从客户端传来的数据完毕");
OutputStream outStream=socket.getOutputStream();
DataOutputStream dataout=new DataOutputStream(outStream); //给客户端发送的数据
System.out.println("写给客户端的话");
Scanner sc=new Scanner(System.in);
String strcontent=sc.next();
dataout.writeUTF(strcontent);
System.out.println("通讯完毕");
socket.shutdownInput();//关流
socket.shutdownOutput();
socket.close(); } catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} }
package Socket;

import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.Scanner; import javax.xml.stream.util.StreamReaderDelegate; public class MyChatClient { public static void main(String[] args) { try {
//表示客户端连接的主机的地址
Socket socket=new Socket(MyChatServer.ADDRESS,MyChatServer.PORT);
System.out.println("客户端连接服务器成功");
System.out.println("请输入想服务器发送的内容");
OutputStream outStream=socket.getOutputStream();
//把数据打印出来
DataOutputStream outWriter=new DataOutputStream(outStream) ;
//给服务端发送的数据
System.out.println("写给服务器的话");
Scanner sc=new Scanner(System.in);
String strcontent=sc.nextLine();
outWriter.writeUTF(strcontent);
//接收服务端发来的数据
InputStream inputStream=socket.getInputStream();
//把数据打印出来
DataInputStream dataRead=new DataInputStream(inputStream) ;
String str;
System.out.println("服务器传来的数据");
while((str=dataRead.readUTF())!=null){
System.out.println(str);
}
System.out.println("从服务器传过来的数据完毕");
System.out.println("通讯完毕");
socket.shutdownInput();
socket.shutdownOutput();
socket.close();
} catch (UnknownHostException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} }

网络应用软件结构-----CS与BS结构(网络基本知识小结)的更多相关文章

  1. 什么是CS和BS结构,两种结构的区别

    什么是CS和BS结构,两种结构的区别 什么是C/S和B/S结构?         C/S又称Client/Server或客户/服务器模式.服务器通常采用高性能的PC.工作站或小型机,并采用大型数据库系 ...

  2. 1.cs与bs结构

    ####CS 与 BS 结构 C/S 结构软件:客户端(Client)服务器(Server)软件,客户端需要单独下载安装之后,才能正常操作的软件 B/S 结构软件:浏览器(Browser)服务器(Se ...

  3. 容器化之路Docker网络核心知识小结,理清楚了吗?

    Docker网络是容器化中最难理解的一点也是整个容器化中最容易出问题又难以排查的地方,加上使用Kubernets后大部分人即使是专业运维如果没有扎实的网络知识也很难定位容器网络问题,因此这里就容器网络 ...

  4. CS 和 BS 的区别和优缺点

    通俗来讲: bs是浏览器(browser)和服务器(server) cs是静态客户端程序(client)和服务器(server) 区别在于,虽然同样是通过一个程序连接到服务器进行网络通讯,但是bs结构 ...

  5. CS 和 BS 的区别和优缺点(转)

    转自:http://www.cnblogs.com/scnuyz/p/5808808.html bs是浏览器(browser)和服务器(server) cs是静态客户端程序(client)和服务器(s ...

  6. Java和.Net在做BS结构项目的比较

    渊源: Java的J2EE在1999年形成了其成熟的架构,并且到今天已经有相当成熟的经过检验的企业应用系统.而.Net究其渊源是源自微软以前开发企业应用程序的平台DNA(DistributedNetw ...

  7. 深入理解BS结构应用程序

    随着学习的深入,和编程经验的丰富,对BS应用程序有一些认识. 在一些讨论软件技术的QQ群里,或一些社区.BBS中,经常会有一些初学者会犯一些认知性的错误.比如经常会有一些朋友提这样的一些问题:“我怎么 ...

  8. 一文明白所谓的CS与BS设计模式

    CS设计模式 概念:CS设计模式,C代表的是Client,S代表的是Server.正如图中的所示,是客户机与服务器之间的交互.这种交互在早期的软件系统中,大多数都是采用这种模式,通过将任务合理分配到C ...

  9. Java 网络编程(一) 网络基础知识

    链接地址:http://www.cnblogs.com/mengdd/archive/2013/03/09/2951826.html 网络基础知识 网络编程的目的:直接或间接地通过网络协议与其他计算机 ...

随机推荐

  1. Android开发——进程间通信之AIDL(二)

    0.  前言 不论是Android还是其它操作系统.都会有自己的IPC机制.所谓IPC(Inter-Process Communication)即进程间通信.首先线程和进程是非常不同的概念,线程是CP ...

  2. odoo高级物流应用:跨厂区生产

    业务情景 半成品在分厂生产,然后再在总厂组装 半成品所需的原材料存储在分厂的仓库 总厂需要的原材料储存在总厂的仓库 公用的原材料储存在总厂的仓库     解决方案 使用仓库间的供应 设置合适的Rout ...

  3. Spring延迟加载

    如下内容引用自:http://www.cnblogs.com/wcyBlog/p/3756624.html 1.Spring中lazy-init详解ApplicationContext实现的默认行为就 ...

  4. java开始到熟悉105-107

    1,HashMap基本用法 package list; import java.util.HashMap; import java.util.Map; /** * 测试map的基本用法 * @auth ...

  5. Android学习系列(二)布局管理器之线性布局的3种实现方式

    转载请注明出处:http://blog.csdn.net/lhy_ycu/article/details/39643669 LinearLayout是Android控件中的线性布局控件,它包括的子控件 ...

  6. python-pyDes-ECB加密-DES-DES3加密

    网上的教程都他妹的是抄的,抄也就算了,还改抄错了,害我写了一两天都没找到原因,直接去官网看,找例子很方便 官网链接:http://twhiteman.netfirms.com/des.html 一个小 ...

  7. Struts2 (三) (转载)

    前面一直在说Action可以是一个普通的Java类,与Servlet API完全分离,但是为了实现业务逻辑,Action需要使用HttpServletRequest内容.Struts 2设计的精巧之处 ...

  8. 基于UDP的一对回射客户/服务器程序

    前言 之前曾经学习过一对回射客户/服务器程序的例子,不过那个是基于TCP协议的.本文将讲解另一对回射客户/服务器程序,该程序基于UDP协议.由于使用的协议不同,因此编写出的程序也有本质上的区别,应将它 ...

  9. Python 008- 游戏2048

    #-*- coding:utf-8 -*- import curses from random import randrange, choice # generate and place new ti ...

  10. 《MySQL必知必会学习笔记》:子查询

    子查询 在開始了解子查询之前,首先做下准备工作,建立3个表, 一个是customers表,当中包含:客户名字.客户ID.客户Tel等. 一个是orders表,当中包含:订单号.客户ID.订单时间等. ...