UEditor编辑器和php简单的实现socket通信

一、UEditor编辑器

使用这个编辑器是需要先下载编辑器文件,记得下载的时候放入自己的网站中,既然是php中使用,自然我下载的就是php的UEditor编辑器了,然后是utf-8的

其实使用很简单,就是将你下载后中的几个js文件先引入

(1)按照文件说明,可以引入这几个文件(注意自己的文件保存路径)

<script id="container" name="content" type="text/plain">
            这里是打开编辑器时显示的内容
</script>

<!-- 配置文件 -->
<script type="text/javascript" src="UEditor/utf8-php/ueditor.config.js"></script>

<!-- 编辑器源码文件 -->
<script type="text/javascript" src="UEditor/utf8-php/ueditor.all.js">
</script>

<!-- 实例化编辑器 -->
<script type="text/javascript">
            var ue = UE.getEditor(‘container‘);
</script>

运行之后就是这样了

(2)可以根据自己的需要修改这个编辑框的高和宽

只要加入属性就可以了


1

2

3

<script id="container" name="content" type="text/plain" style="width:1000px;height:300px;">

            这里是打开编辑器时显示的内容

</script>

(3)设置和读取编辑器的内容

通 getContent 和 setContent 方法可以设置和读取编辑器的内容


1

2

3

4

5

6

7

8

9

10

ue.ready(function() {

    //设置编辑器的内容

    ue.setContent(‘hello‘);

            

    //获取html内容,返回: <p>hello</p>

    var html = ue.getContent();

    //获取纯文本内容,返回: hello

    var txt = ue.getContentTxt();

});

这就是设置的编辑器内容:

配置项也可以通过 ueditor.config.js 文件修改,比如保存位置,默认的大小,等等

还有很多的功能,查看官网吧

二、php简单的实现socket通信

php里面如何实现socket通信

先从服务器端说起。服务器端先初始化Socket,然后与端口绑定(bind),对端口进行监听(listen),调用accept阻塞,等待客户端连接。在这时如果有个客户端初始化一个Socket,然后连接服务器(connect),如果连接成功,这时客户端与服务器端的连接就建立了。客户端发送数据请求,服务器端接收请求并处理请求,然后把回应数据发送给客户端,客户端读取数据,最后关闭连接,一次交互结束。

由于socket服务端的代码要监听端口,等待接收请求,所以php在做socket服务的时候需要将php文件运行在CMD里面。

如果要使php文件可以在CMD里面运行,则需要进行如下设置:

1.添加环境变量,名字为PHP_HOME,值为php文件安装目录下的.exe文件地址,如 D:\wamp\bin\php\php5.5.12\php.exe(注意是你自己的下载的位置)

环境变量怎么打开?

(1)右键单击“计算机”---“属性”,打开的窗口

(2)在左边的栏中选择“高级系统设置”,打开“系统属性”对话框,单击“环境变量”

(3)打开环境变量对话框,开始添加环境变量(添加就不多说了,新建就可以了)

2.修改系统变量path的值

在path的值里面添加php安装的目录:如 D:\wamp\bin\php\php5.5.12;

到这里我们就配置好了环境变量,下一步我们打开CMD,想要在里面运行php文件,比如1.php文件

看下我的这个php文件

  运行结果     

然后cmd的环境下运行(路径一定要写对!!!)

php文件能够成功在cmd里面运行了。

3.socket相关函数:

socket_accept() 接受一个Socket连接
socket_bind() 把socket绑定在一个IP地址和端口上
socket_clear_error() 清除socket的错误或者最后的错误代码
socket_close() 关闭一个socket资源
socket_connect() 开始一个socket连接
socket_create_listen() 在指定端口打开一个socket监听
socket_create_pair() 产生一对没有区别的socket到一个数组里
socket_create() 产生一个socket,相当于产生一个socket的数据结构
socket_get_option() 获取socket选项
socket_getpeername() 获取远程类似主机的ip地址
socket_getsockname() 获取本地socket的ip地址
socket_iovec_add() 添加一个新的向量到一个分散/聚合的数组
socket_iovec_alloc() 这个函数创建一个能够发送接收读写的iovec数据结构
socket_iovec_delete() 删除一个已经分配的iovec
socket_iovec_fetch() 返回指定的iovec资源的数据
socket_iovec_free() 释放一个iovec资源
socket_iovec_set() 设置iovec的数据新值
socket_last_error() 获取当前socket的最后错误代码
socket_listen() 监听由指定socket的所有连接
socket_read() 读取指定长度的数据
socket_readv() 读取从分散/聚合数组过来的数据
socket_recv() 从socket里结束数据到缓存
socket_recvfrom() 接受数据从指定的socket,如果没有指定则默认当前socket
socket_recvmsg() 从iovec里接受消息
socket_select() 多路选择
socket_send() 这个函数发送数据到已连接的socket
socket_sendmsg() 发送消息到socket
socket_sendto() 发送消息到指定地址的socket
socket_set_block() 在socket里设置为块模式
socket_set_nonblock() socket里设置为非块模式
socket_set_option() 设置socket选项
socket_shutdown() 这个函数允许你关闭读、写、或者指定的socket
socket_strerror() 返回指定错误号的详细错误
socket_write() 写数据到socket缓存
socket_writev() 写数据到分散/聚合数组

(1)服务器的文件

重要的步骤:

+-------------------------------
* @socket_create    socket_create() 产生一个socket,相当于产生一个socket的数据结构
* @socket_bind      socket_bind() 把socket绑定在一个IP地址和端口上
* @socket_listen     socket_listen() 监听由指定socket的所有连接
* @socket_accept   socket_accept() 接受一个Socket连接
* @socket_read      socket_read() 读取指定长度的数据
* @socket_write     socket_write() 写数据到socket缓存
* @socket_close     socket_close() 关闭一个socket资源


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

<?php

header("Content-Type: text/html; charset=utf-8");

//确保在连接客户端时不会超时

set_time_limit(0);

//设置IP和端口号

$ip = "127.0.0.1";

$port = "1900";

/*----------------    以下操作都是手册上的    -------------------*/

//产生一个socket,相当于产生一个socket的数据结构

//AF_INET=是ipv4 如果用ipv6,则参数为 AF_INET6

//SOCK_STREAM为socket的tcp类型,如果是UDP则使用SOCK_DGRAM

if(($sock = socket_create(AF_INET,SOCK_STREAM,SOL_TCP)) < 0) {

    echo "socket_create() 失败的原因是:".socket_strerror($sock)."\n";

}

//把socket绑定在一个IP地址和端口上

if(($ret = socket_bind($sock,$ip,$port)) < 0) {

    echo "socket_bind() 失败的原因是:".socket_strerror($ret)."\n";

}

//监听由指定socket的所有连接

if(($ret = socket_listen($sock,4)) < 0) {

    echo "socket_listen() 失败的原因是:".socket_strerror($ret)."\n";

}

$count = 0;

do {

    if (

    //接受一个Socket连接它接收连接请求并调用一个子连接Socket来处理客户端和服务器间的信息

    ($msgsock = socket_accept($sock)) < 0) {

        echo "socket_accept() failed: reason: " . socket_strerror($msgsock) . "\n";

        break;

        }

  else {

 

        //获得客户端的输入

        $buf = socket_read($msgsock,8192);

        

        $talkback = "收到的信息:$buf\n";

        echo $talkback;

        

    //处理客户端输入并返回结果

    $msg ="测试成功!\n";

        socket_write($msgsock, $msg, strlen($msg));

        

        echo "测试成功了啊\n";

        

        if(++$count >= 5){

            break;

        };

    }

    //echo $buf;

    socket_close($msgsock);

} while (true);

socket_close($sock);

?>

在cmd环境下运行这个服务器文件,(乱码有点)

查看是不是出于监听状态,在cmd环境中输入netstat -ano

(2)客户端文件 

重要的步骤:

+-------------------------------
* @socket_create
* @socket_connect    socket_connect() 开始一个socket连接
* @socket_write
* @socket_read
* @socket_close


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

<?php

header("Content-Type: text/html; charset=utf-8");<br>//显示所有错误

error_reporting(E_ALL);

set_time_limit(0);

echo "<h2>TCP/IP Connection</h2>\n";<br>

//IP和端口号

$port = 1935;

$ip = "127.0.0.1";

 

//创建一个socket

$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);

if ($socket < 0) {

    echo "socket_create() failed: reason: " . socket_strerror($socket) . "\n"//失败的原因

}

else

{

    echo "OK.\n"//成功

}

echo "试图连接 ‘$ip‘ 端口 ‘$port‘...\n";

//开始socket链接

$result = socket_connect($socket, $ip, $port); 

if ($result < 0) {

    echo "socket_connect() failed.\nReason: ($result) " . socket_strerror($result) . "\n";

}else {

    echo "连接OK\n";

}

$in = "Ho\r\n";

$in .= "first blood\r\n";

$out = ‘‘;

<br>//strlen()是返回字符串长度

if(!socket_write($socket, $in, strlen($in))) {

    echo "socket_write() failed: reason: " . socket_strerror($socket) . "\n";

}else {

    echo "发送到服务器信息成功!\n";

    echo "发送的内容为:<font color=‘red‘>$in</font> <br>";

}

while($out = socket_read($socket, 8192)) {

    echo "接收服务器回传信息成功!\n";

    echo "接受的内容为:",$out;

}

echo "关闭SOCKET...\n";

socket_close($socket);

echo "关闭OK\n";

?>

在cmd环境下运行客户端文件,注意保存路径是不是正确的(我这有乱码啊),但是可以看出是正确的

上面的乱码也就是浏览器显示出来的

时间: 2024-08-09 19:58:36

UEditor编辑器和php简单的实现socket通信的相关文章

百度富文本编辑器ueditor/jsp版的简单使用,可上传图片和附件

~~经过一上午的时间,终于把ueditor编辑器搞出来了,仅做记录 #完成的样子 1,首先在官网下载对应的插件 [附下载地址:http://ueditor.baidu.com/website/download.html]    本人使用的是Java语言 ,框架是ssm+maven 2,解压文件,在自己项目的根目录下新建文件夹 ueditor,把utf8-jsp中文件复制粘贴到ueditor文件夹下 3,新建一个ueditorTest.jsp,把文件夹中index.html中的HTML代码复制粘贴

百度UEditor编辑器使用教程与使用方法

我们在做网站的时候,网站后台系统一般都会用到web编辑器,今天笔者就给大家推荐一款百度UEditor编辑器.关于这款百度UEditor编辑器官网上也有简单的教程,不过看着比较费劲,今天笔者就跟大家分享一下百度UEditor编辑器使用教程与使用方法,希望对大家有所帮助. 第一:百度UEditor编辑器的官方下载地址 ueditor 官方地址:http://ueditor.baidu.com/website/index.html 开发文档地址:http://ueditor.baidu.com/web

ueditor编辑器使用总结

ueditor使用小结 一.简介 ueditor是百度编辑器,官网地址:http://ueditor.baidu.com/website/ 完整的功能演示,可以参考:http://ueditor.baidu.com/website/onlinedemo.html 为了方便开发学习,我们下载它的完整版和.net版. ueditor_release_ueditor1_4_3_1-src.zip ueditor_release_ueditor1_4_3_1-gbk-net.zip 二.如何引入uedi

tp中ueditor编辑器的使用

1/引入三个文件 <script type="text/javascript" charset="utf-8" src="{$Think.config.PLUGIN_URL}ueditor/ueditor.config.js"></script><script type="text/javascript" charset="utf-8" src="{$Think.co

Android简单Socket通信demo

一.Android Socket 通信简介 Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客户端向服务器发送请求后,服务器端才能向客户端返回数据.而Socket通信则是在双方建立起连接后就可以直接进行数据的传输,在连接时可实现信息的主动推送,而不需要每次由客户端想服务器发送请求. 那么,什么是socket?Socket又称套接字,在程序内部提供了与外界通信的端口,即端口通信

C# 如何实现简单的Socket通信(附示例)

上周由于有个项目需要用到网络通信这块,然后就花了点时间研究了一下,本来想上周就写出来的,但是突然要忙,所以等到现在. 话说对于网络通信,以前写C++的时候,天天面对着线程和Socket,所以换成C#也就没那么怕了,虽然C++下也没有掌握的多好,但毕竟只是一个小Demo,只作为了解一下过程. 自己写了一个服务端和一个客户端,刚开始比较简单,只是能达到连通,收发信息的目的,但是很粗糙.而后稍加改进呢~加上了多线程,所以能感觉更科学一些,不过自己真的很菜,代码写的不是很好看,下面分两个版本给大家表出来

(六)在线文档编辑器的使用和数据字典(ueditor编辑器/my97datepicker日期控件)

使用ueditor编辑器注意: 1. 要把ueditor的jar包添加到WEB-INF/lib里. 2. 在做图片上传等功能时,必须重写struts的过滤器,否则图片流会被拦截程序无法得到图片. 3. 上传的图片(还未经过action处理)一般放在 "C:\Users\Administrator\workspace\.metadata\.plugins\org.eclipse.wst.server.core\tmp1\wtpwebapps/项目名"的目录下.

Thinkphp整合最新Ueditor编辑器

说到最新的富文本编辑器的确不少(ckeditor.fkeditor.ueditor),这些富文本编辑器如果单独使用基本上很方便,不需要做额外的配置,只要把官方的插件下载下来放到一个web容器中,看看 插件中提供的 index.html 里的代码就明白应该怎么调用了.因为富文本编辑器会经常涉及到文件.图片.视频资源的上传,如果本身所用到的框架或者是项目本身就有一个模块是专门来处理这一块儿的,对一些资源需要做特殊处理的,例如水印处理,对图片的大小处理(原图.缩略图),那么就设计到把富文本编辑器与你现

一个最简单的Socket通信例子

所谓socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄.应用程序通常通过"套接字"向网络发出请求或者应答网络请求.  Socket和ServerSocket类库位于java.net包中.ServerSocket用于服务器端,Socket是建立网络连接时使用的.在连接成功时,应用程序两端都会产生一个Socket实例,操作这个实例,完成所需的会话.对于一个网络连接来说,套接字是平等的,并没有差别,不因为在服务器端或在客户端而产生不同级别.不管是