当前位置:  编程技术>移动开发
本页文章导读:
    ▪兑现一个大容量、高并发的tcp代理,模拟移动网络报文延迟的情况        实现一个大容量、高并发的tcp代理,模拟移动网络报文延迟的情况       测试移动互联网应用时,因为现实的网络中,延迟非常严重,而实验环境很难出现延迟,比如ssl连接时,在实验室.........
    ▪ win8开发(七)——资源限定符和资源映射        win8开发(7)——资源限定符和资源映射 上一篇文章中,我们吹了一下资源和本地化,同时也做了一个实例,本文我们再深入探索一下资源限定符和资源路径的映射。这两个玩意儿也许我.........
    ▪ SecureCRT展示乱码解决       SecureCRT显示乱码解决最近经常使用SecureCRT对linux进行配置,以前都是直接在Linux runlevel 3模式下通过命令行界面进行配置,时间长了发现很不方便,比方说复制、粘贴一些配置文件或指令,无.........

[1]兑现一个大容量、高并发的tcp代理,模拟移动网络报文延迟的情况
    来源: 互联网  发布时间: 2014-02-18
实现一个大容量、高并发的tcp代理,模拟移动网络报文延迟的情况

       测试移动互联网应用时,因为现实的网络中,延迟非常严重,而实验环境很难出现延迟,比如ssl连接时,在实验室很难出现握手很慢的情况。而直接现网验证风险又很大,心里没底。

       所以在网络中增加一个tcp proxy,终端连接到proxy,proxy连接到服务端,在proxy中人为的随机延迟报文。所有基于TCP的协议都可以使用这个代理,比如http、ssl等。


从开发的难度、并发要求等情况考虑,使用erlang是一个比较合适的选择。

下面是代码,c(tcp_proxy).后,运行

tcp_proxy:start(客户端连接的端口, "192.168.9.145", 服务端的端口).

然后终端连接“客户端连接的端口”,每建一个连接,代理都起一个独立的进程,连接到服务端,然后在终端与服务端之间转发报文,不做任何解析。

在process中,可以延迟,也可以丢包,甚至可以改写报文。



%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

-module(tcp_proxy).

-export([
    start/3,
    server/3,
    process/1,
    loop/2
]).

start(LPort, DHost, DPort) ->
    case gen_tcp:listen(LPort,[{active, true},{packet,raw}]) of
        {ok, ListenSock} ->
            spawn(?MODULE, server, [ListenSock, DHost, DPort]),
            {ok, Port} = inet:port(ListenSock),
            Port;
        {error,Reason} ->
            {error, Reason}
    end
.

%% tcp_proxy:start(客户端连接的端口, "192.168.9.145", 服务端的端口).

server(LSocket, DHost, DPort) ->
    io:format("Server started ~n"),
    case gen_tcp:accept(LSocket) of
        {ok, SrcSocket} ->
            io:format("Got connect ~n"),
            case gen_tcp:connect(DHost, DPort, [binary, {packet,raw}, {active, true}]) of
            {ok, DstSocket} ->
                io:format("Connect to dest server ~n"),
                Pid = spawn_link(fun() -> loop(SrcSocket, DstSocket) end),
                gen_tcp:controlling_process(DstSocket, Pid),
                gen_tcp:controlling_process(SrcSocket, Pid);
                
            E ->
                io:format("Error:Connect failed!~n"),
                E
            end,
            
            ok;
        
        Other ->
            io:format("Error: accept returned ~w - finita!~n",[Other]),
            ok
    end,
    
    server(LSocket, DHost, DPort)
.

loop(SrcSocket, DstSocket) ->
    %% inet:setopts(SrcSocket, [{active,once}]),
    receive
        {tcp, SrcSocket, Data} ->
            %%Len = length(Data),
            %%io:format("Received tcp(SrcSocket,~p) ~p ~n",[Len, Data]),
            case process(Data) of % you can poke around with the data
                {ok, RetData} ->
                    %%io:format("Send to tcp(DstSocket,~p) ~p ~n",[Len, RetData]),
                    gen_tcp:send(DstSocket, RetData);
                error ->
                    io:format("discarded~n"),
                    ok
            end,
            loop(SrcSocket, DstSocket); % erlang awesomeness. no loops ;)
            
        {tcp, DstSocket, Data} ->
            %%Len = size(Data),
            %%io:format("Received tcp(DstSocket,~p) ~p ~n", [Len, Data]),
            case process(Data) of % you can poke around with the data
                {ok, RetData} ->
                    %%io:format("Send to tcp(SrcSocket,~p) ~p ~n",[Len, RetData]),
                    gen_tcp:send(SrcSocket, RetData);
                error ->
                    io:format("discarded~n"),
                    ok
            end,
            loop(SrcSocket, DstSocket);

        {tcp_closed, SrcSocket} ->
            gen_tcp:close(DstSocket),
            io:format("DstSocket ~w closed [~w]~n",[SrcSocket,self()]),
            ok;
            
        {tcp_closed, DstSocket}->
            gen_tcp:close(SrcSocket),
            io:format("DstSocket (SrcSocket) ~w closed [~w]~n",[SrcSocket,self()]),
            ok
    end
.

%% 改这里,模拟不同的网络环境,当前实现:50%的情况下,报文会延迟0-10秒
process(Data) ->
    R = random:uniform(100),
    if
        R > 50 ->
            timer:sleep(random:uniform(10000)),
            {ok, Data};
        true ->
            {ok, Data}
    end
.

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%


    
[2] win8开发(七)——资源限定符和资源映射
    来源: 互联网  发布时间: 2014-02-18
win8开发(7)——资源限定符和资源映射

上一篇文章中,我们吹了一下资源和本地化,同时也做了一个实例,本文我们再深入探索一下资源限定符和资源路径的映射。这两个玩意儿也许我们在实际开发中并不十分关注,不过,了解一下,还是有好处的。
这两个名词看起来就抽象,或者,我们会感觉到,从文字描述无法理解它们,那么,老规矩,我们还是用实验来看看是否能将抽象的概念形象化。

1、启动VS,新建一个Modern风格的应用程序项目(也就前面说过的板砖风格)。
2、在“资源管理器”中的项目节点上右击,从快捷菜单中依次选择“添加”-“新建项”,在模板列表中找到资源文件(.resw),文件名按默认Resources即可,确定。
3、在刚才新建的资源文件中,随便输入一些资源,如图:
 


4、保存并关闭资源文件,另外,在项目中新建两个空白页面,分别为PageQt.xaml和PageMaps.xaml,现在,你的结构应该类似下图所示。

 

(1)打开PageQt.xaml,界面布局参考下面的XAML。
    <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">  
    <TextBlock Name="tb" FontSize="20" TextWrapping="Wrap" Margin="3"/>  
    </Grid>  

切换到PageQt.xaml.cs,C#代码如下所示。



  • using System;
  • using System.Collections.Generic;
  • using System.IO;
  • using System.Linq;
  • using Windows.Foundation;
  • using Windows.Foundation.Collections;
  • using Windows.UI.Xaml;
  • using Windows.UI.Xaml.Controls;
  • using Windows.UI.Xaml.Controls.Primitives;
  • using Windows.UI.Xaml.Data;
  • using Windows.UI.Xaml.Input;
  • using Windows.UI.Xaml.Media;
  • using Windows.UI.Xaml.Navigation;
  • // 引入以下命名空间
  • using Windows.ApplicationModel.Resources;
  • using Windows.ApplicationModel.Resources.Core;
  • namespace MyApp
  • {
  •     /// <summary>
  •     /// 可用于自身或导航至 Frame 内部的空白页。
  •     /// </summary>
  •     public sealed partial class PageQt : Page
  •     {
  •         public PageQt()
  •         {
  •             this.InitializeComponent();
  •             this.Loaded += PageQt_Loaded;
  •         }
  •         void PageQt_Loaded(object sender, RoutedEventArgs e)
  •         {
  •             ResourceContext context = ResourceManager.Current.DefaultContext;
  •             string resultStr = string.Empty;
  •             foreach (var item in context.QualifierValues)
  •             {
  •                 resultStr += string.Format("{0} => {1}", item.Key, item.Value);
  •                 resultStr += "\n";
  •             }
  •             this.tb.Text = resultStr;
  •         }
  •     }
  • }
(3)保存,接着打开PageMaps.xaml,XAML如下所示。


  • <Page
  •     x:
  •     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  •     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  •     xmlns:local="using:MyApp"
  •     xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  •     xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  •     mc:Ignorable="d">
  •     <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">
  •         <TextBlock Name="tb" FontSize="20" TextWrapping="Wrap" Margin="3"/>
  •     </Grid>
  • </Page>
切换到C#代码视图,处理代码如下面清单所示:



  • using System;
  • using System.Collections.Generic;
  • using System.IO;
  • using System.Linq;
  • using Windows.Foundation;
  • using Windows.Foundation.Collections;
  • using Windows.UI.Xaml;
  • using Windows.UI.Xaml.Controls;
  • using Windows.UI.Xaml.Controls.Primitives;
  • using Windows.UI.Xaml.Data;
  • using Windows.UI.Xaml.Input;
  • using Windows.UI.Xaml.Media;
  • using Windows.UI.Xaml.Navigation;
  • // 引用以下命名空间
  • using Windows.ApplicationModel.Resources;
  • using Windows.ApplicationModel.Resources.Core;
  • namespace MyApp
  • {
  •     public sealed partial class PageMaps : Page
  •     {
  •         public PageMaps()
  •         {
  •             this.InitializeComponent();
  •             this.Loaded += (sender, args) =>
  •                 {
  •                     string str = "";
  •                     foreach (var item in ResourceManager.Current.AllResourceMaps)
  •                     {
  •                         str += "-------------------- " + item.Key + " --------------------\n";
  •                         foreach (var x in item.Value)
  •                         {
  •                             str += string.Format("{0} => {1}\n", x.Key, x.Value.Uri);
  •                         }
  •                         str += "\n\n";
  •                     }
  •                     this.tb.Text = str;
  •                 };
  •         }
  •     }
  • }
5、现在回到MainPage.xaml,把页面根Grid分为两列,左边放一个ListBox,右边放一个Frame,相信你也猜到用来干啥的,对,就是用Frame来导航显示前面我们做的两个页面,一个显示资源限定符信息,另一个显示路径映射。



  • <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">
  •     <Grid.ColumnDefinitions>
  •         <ColumnDefinition Width="150"/>
  •         <ColumnDefinition/>
  •     </Grid.ColumnDefinitions>
  •     <ListBox Name="lb" Grid.Column="0" SelectionChanged="onSelectionChanged">
  •         <ListBoxItem>资源限定符</ListBoxItem>
  •         <ListBoxItem>资源映射</ListBoxItem>
  •     </ListBox>
  •     <Frame x:Name="frameRight" Grid.Column="1" Margin="2"/>
  • </Grid>
        [C# Code]



  • using System;
  • using System.Collections.Generic;
  • using System.IO;
  • using System.Linq;
  • using Windows.Foundation;
  • using Windows.Foundation.Collections;
  • using Windows.UI.Xaml;
  • using Windows.UI.Xaml.Controls;
  • using Windows.UI.Xaml.Controls.Primitives;
  • using Windows.UI.Xaml.Data;
  • using Windows.UI.Xaml.Input;
  • using Windows.UI.Xaml.Media;
  • using Windows.UI.Xaml.Navigation;
  • // “空白页”项模板在http://go.microsoft.com/fwlink/?LinkId=234238上有介绍
  • namespace MyApp
  • {
  •     /// <summary>
  •     /// 可用于自身或导航至 Frame 内部的空白页。
  •     /// </summary>
  •     public sealed partial class MainPage : Page
  •     {
  •         public MainPage()
  •         {
  •             this.InitializeComponent();
  •         }
  •         /// <summary>
  •         /// 在此页将要在 Frame 中显示时进行调用。
  •         /// </summary>
  •         /// <param name="e">描述如何访问此页的事件数据。Parameter
  •         /// 属性通常用于配置页。</param>
  •         protected override void OnNavigatedTo(NavigationEventArgs e)
  •         {
  •             lb.SelectedIndex = 0;
  •         }
  •         private void onSelectionChanged(object sender, SelectionChangedEventArgs e)
  •         {
  •             ListBox lb = sender as ListBox;
  •             if (lb!=null)
  •             {
  •                 int index = lb.SelectedIndex;
  •                 switch (index)
  •                 {
  •                     case 0:
  •                         this.frameRight.Navigate(typeof(PageQt));
  •                         break;
  •                     case 1:
  •                         this.frameRight.Navigate(typeof(PageMaps));
  •                         break;
  •                     default:
  •                         this.frameRight.Navigate(typeof(PageQt));
  •                         break;
  •                 }
  •             }
  •         }
  •     }
  • }
6、打开清单文件Package.appxmanifest,然后切换到“打包”选项卡,把包名改一下,改成一个好看一点,方便查看的名字。后面有用。 

现在,运行一下。

 

 
从第一张截图中,我们可以大概知道什么是资源限定符,上一篇文章中我们的例子,实现简/繁体中文切换,我们用到了限定符中的一种——语言标记。从图中我们看到,限定符有:
Language:当前应用首选的语言;
Contrast:对比度。
Scale:缩放比例。
HomeRegion:区域。
And so on.
如果你想了解更多有关限定符的东东,可以看看官方的文档。
官方文档
这东西没什么技巧可言,你就按照文档说的去做就行了。

再来看看路径映射,前面我们修改包名,就是为了在这里好查看,

 
不知道各位在上面的截图中发现了什么规律?
1、资源路径是以ms-resource:// 打头的。
2、应用程序所认为的资源不仅仅是.resw文件,看上图,几乎把我们项目中的所有文件都列出来了。
3、那么,我们在引用某项资源时,是按key来引用的,也就是图中“=>”左边的内容。
4、重点关注一下Resources.resw的映射,从图中我们看到,Resources.resw的引用名为Resources,这个名字是默认的,还记得上一篇文章中的例子吗?我们实例化ResourceLoader时,是调用了无参数的构造函数,那是因为Resources是默认值,如果我们添加的资源文件是abc.resw,那么我们在实例化ResourceLoader时,就不能用无参构造函数了,而要传递一个引用名,按照上面我们实验得出的规律,引用名应当是abc。
继续回到上图,在Resources下的两个资源项也被映射到不同的URI,即Resources/Key1和Resources/Key2,所以,以后要引用资源,你应该懂得怎么做了。
ResourceMap类有个GetSubtree方法,它可以返回指定引用的子映射,比如,上图中,如果调用GetSubtree("Resources"),这样,返回的Map就只剩下Key1和Key2了,就是我们要找的资源项,然后在返回的ResourceMap上再调用GetValue("Key1"),就能取到资源了。

下面再做实例,看看如何从ResourceMap映射中取出资源项的值。
1、新建项目。
2、在MainPage.xaml中完成布局。


  • <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">  
  •     <StackPanel Margin="25">  
  •         <TextBlock FontSize="20" Text="第一个值:"/>  
  •         <TextBlock FontSize="24" Name="tb1"/>  
  •          
  •         <TextBlock FontSize="20" Margin="0,20,0,0" Text="第二个值:"/>  
  •         <TextBlock FontSize="24" Name="tb2"/>  
  •     </StackPanel>  
  • </Grid>  
3、切换到C#代码视图。


  • protected override void OnNavigatedTo(NavigationEventArgs e)  
  • {  
  •     ResourceMap map = ResourceManager.Current.MainResourceMap.GetSubtree("Resources");  
  •     tb1.Text = map.GetValue("v1").ValueAsString;  
  •     tb2.Text = map.GetValue("v2").ValueAsString;  
  • }  

然后,运行程序,查看效果

3.png (9.05 KB, 下载次数: 0)


    
[3] SecureCRT展示乱码解决
    来源: 互联网  发布时间: 2014-02-18
SecureCRT显示乱码解决
最近经常使用SecureCRT对linux进行配置,以前都是直接在Linux runlevel 3模式下通过命令行界面进行配置,时间长了发现很不方便,比方说复制、粘贴一些配置文件或指令,无法向前滚屏等等,经人介绍和自己实际使用发现SecureCRT挺不错。

  用了一阵之后才注意到经常会出现一些乱码,当时也没太在意,后来无意中发现同事使用的汉化版SecureCRT上没有出现这种情况,我用的英文原版的上面显示乱码的地方在汉化版上显示出来的竟然是中文,如下图所示:

   

  一开始以为是因为我的英文版不支持中文显示而乱码。后来仔细考虑了一下发现这个问题没有这么简单,问题的关键是为什么用SecureCRT通过命令行进行配置默认会显示中文呢,查阅了一些资料后发现这牵涉到一个文件/etc/sysconfig/i18n,“i18n”这个文件名称是internationalization的缩写,意即在i和n之间有18 个字母,本意是指软件的“国际化”。

  这个文件只有一行内容

  

我用的环境是(RHEL Server release 5.1,Kernel 2.6.18-53.e15)这一行的意思表明你当前系统的语言环境变量设置。

  从上面我们可以清楚的看到系统默认的语言环境变量是zh_CN.UTF-8,英文版的SecureCRT根据这个设置来显示相关中文信息时则会出现乱码。怎么解决呢?只需把LANG="zh_CN.UTF-8" 改为LANG="en_US.UTF-8"或者LANG="zh_CN.GB18030"即可。

  接下来最好在SecureCRT的Options选项中选择Session Options,修改Appearance中的字符编码为

UTF-8。

        

    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
linux iis7站长之家
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3