没有合适的资源?快使用搜索试试~ 我知道了~
嵌入式系统/ARM技术中的关于Linux跨网络运行X Window程序
0 下载量 174 浏览量
2020-11-08
00:23:33
上传
评论
收藏 77KB PDF 举报
温馨提示
试读
3页
X Window在设计上就是跨网络的,X Client是需要图形显示的应用程序, X Server则负责具体显示和传递用户交互行为。二者之间通信的协议称为 X Protocol,X协议。 基于主机验证的X Window配置 (1) 在X Server端,加入允许发送X Request的机器地址。 $ xhost +192.168.0.1关于xhost的用法示例: $ xhost -192.168.0.1 #取消192.168.0.1发送X Request到本机$ xhost + #允许所有主机发送X Request到本机$ xhost + #再次执行该命令取消允许所有主
资源推荐
资源详情
资源评论
嵌入式系统嵌入式系统/ARM技术中的关于技术中的关于Linux跨网络运行跨网络运行X Window程程
序序
X Window在设计上就是跨网络的,X Client是需要图形显示的应用程序, X Server则负责具体显示和传递用户交互
行为。二者之间通信的协议称为 X Protocol,X协议。 基于主机验证的X Window配置 (1) 在X Server
端,加入允许发送X Request的机器地址。 $ xhost +192.168.0.1关于xhost的用法示例: $ xhost -
192.168.0.1 #取消192.168.0.1发送X Request到本机$ xhost + #允许所有主机发送X Request到本机$ xhost + #
再次执行该命令取消允许所有主
X Window在设计上就是跨网络的,X Client是需要图形显示的应用程序, X Server则负责具体显示和传递用户交互行为。二
者之间通信的协议称为 X Protocol,X协议。
基于主机验证的X Window配置
(1) 在X Server端,加入允许发送X Request的机器地址。
$ xhost +192.168.0.1关于xhost的用法示例:
$ xhost -192.168.0.1 #取消192.168.0.1发送X Request到本机$ xhost + #允许所有主机发送X Request到本机$ xhost + #
再次执行该命令取消允许所有主机的授权此外,可在/etc/X*.hosts中永久加入某些授权主机,其中*是本机显示编号,比如
X0.hosts。细节可看man xhost的说明。
192.168.0.1192.168.0.2(2) 现在,就可以ssh(可能需要配置ssh转发X11数据,我没尝试过)或者telnet到X Client机器,并
运行X Window应用程序,而显示和操作在X Server端。
$ xeyes -display 192.168.0.254:0其中192.168.0.254是(1)中配置的主机,后面的:0表示发送到0号显示屏幕。有些X程
序不支持-display参数,此时可考虑导出DISPLAY环境变量。
$ export DISPLAY=192.168.0.254:0也许你会问,一台机器可以有多个显示屏幕吗?有的,默认启动的屏幕为0,不过你
还可以启动多个。对于gdm启动X Window的方式,你可以修改/etc/X11/gdm/gdm.conf:
0=/usr/bin/X11/X -bpp 8 vt71=/usr/bin/X11/X -bpp 8 vt9...-bpp.参数指定颜色数,此处为8位色深。vt7表示Ctrl+Alt+F7可
切换到该屏幕,vt9表示Ctrl+Alt+F9。你可以指定任意数目的显示屏幕。
如果要配置不同屏幕的登录界面,可执行如下操作:
$ cp /etc/X11/gdm/Init/Default /etc/X11/gdm/Init/:0$ cp /etc/X11/gdm/Init/Default /etc/X11/gdm/Init/:1然后可修改其中的配
置命令。
对于startx启动X Window的方式,可直接在命令行指定,比如 startx -- :1。
基于每用户验证的X Window配置
基本步骤是:先在X Server端的用户目录生成用户的cookie,然后把该cookie加入到X Client的用户目录。这样X Client程
序运行的时候,会根据当前的DISPLAY搜寻cookie信息,并发送到X Server,从而得到验证。
因此,首先需要在X Server端生成cookie,可用xauth命令。
$ xauthUsing authority file /home/yingyuan/.Xauthorityxauth>list192.168.0.199/unix:0 MIT-MAGIC-COOKIE-1
8432567fa3ae2341xauth>add 192.168.0.199:0 MIT-MAGIC-COOKIE-1 8432567fa3ae2341xauth>list192.168.0.199/unix:0
MIT-MAGIC-COOKIE-1 8432567fa3ae2341192.168.0.199:0 MIT-MAGIC-COOKIE-1 8432567fa3ae2341xauth>exit系统原来
就有了一个cookie,我们用add命令新加了一个。
那么,如何把cookie传递给X Client呢?实现方法有三种,以下分别介绍。
(1) 直接把~/.Xauthority从X Server复制为X Client下的~/.Xauthority。这是最简单的实现办法。
(2) 用xauth的extract和merge命令。
在X Server端,
$ xauth...xauth>extract MyCookie 192.168.0.199:0xauth>exit然后我们把MyCookie文件传到X Client,并在X Client运行
如下命令,
$ xauth...xauth>merge MyCookiexauth>exit(3) 记下X Server端的cookie值(用xauth的list可查看),
$ xauth...xauth>list192.168.0.199/unix:0 MIT-MAGIC-COOKIE-1 8432567fa3ae2341192.168.0.199:0 MIT-MAGIC-
COOKIE-1 8432567fa3ae2341xauth>exit然后在X Client用xauth的add添加到.Xauthority文件。
资源评论
weixin_38740827
- 粉丝: 7
- 资源: 947
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功