日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

分享Flash處理安全策略的經(jīng)驗(yàn)_Flash教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:Flash入門實(shí)例:制作傳統(tǒng)風(fēng)格卷簾動(dòng)畫
本例為Flash鼠繪新手入門系列課程,今天我們來學(xué)習(xí)傳統(tǒng)風(fēng)格卷簾畫的繪制,教程講解的比較詳細(xì),適合Flash初學(xué)者學(xué)習(xí),希望朋友們喜歡。 做了個(gè)簾畫,我把做的過程寫出來,供初學(xué)FLASHR 朋友們交流練習(xí)。 先看下效果吧: 一、畫簾片: 1.新建一圖形元件,名“

很多人在處理安全策略時(shí)遇到問題,我自己也總結(jié)了一些經(jīng)驗(yàn),供大家參考吧.在 Flash Player 9.0.124.0 及以后的版本中,socket策略文件對于任何 Socket 連接都是必需的。也就是說,無論連接到哪一個(gè)端口(即使連接到提供 SWF 文件的同一主機(jī)上的端口),目標(biāo)主機(jī)上都需要套接字策略文件。連接步驟:

0.不論是低于還是高于1024端口,基于文件系統(tǒng)時(shí)都不會請求策略文件,基于網(wǎng)絡(luò)時(shí)才會請求.
1.首先發(fā)出以null結(jié)尾的<policy-file-request/>的消息,檢查服務(wù)器843端口是否有安全策略文件,策略文件格式為:
<cross-domain-policy>
<allow-access-from domain="*" to-ports="80-9000" />
</cross-domain-policy>
發(fā)回策略文件的時(shí)候必要以0結(jié)尾,如果843端口在3秒內(nèi)沒有請求到策略文件或者to-ports配置的端口不允許鏈接,則斷掉鏈接拋securityError,這個(gè)是flash主動(dòng)發(fā)起的.
2. 如果您的客戶端socket或xmlsocket連接中設(shè)置了Security.loadPolicyFile("xmlsocket://服務(wù)地址:應(yīng)用端口"),則連接您的應(yīng)用目標(biāo)端口請求安全策略文件,請求和響應(yīng)的方式如上,不設(shè)置是不會請求的.發(fā)請求是在調(diào)用connect之前.
3.如果您是http請求方式要設(shè)置Security.loadPolicyFile("http://服務(wù)地址/crossdomain.xml"),crossdomain.xml文件內(nèi)容如上,放在網(wǎng)站根目錄就行了.例如mop的http://www.mop.com/crossdomain.xml

解決方案1:使用adobe官方提供的文件直接在服務(wù)器的843端口上建立服務(wù),這樣響應(yīng)速度最快,但對于應(yīng)用的部署就麻煩了http://www.adobe.com/devnet/flashplayer/articles/socket_policy_files.html

解決方案2:客戶端必須加Security.loadPolicyFile("xmlsocket://服務(wù)地址:應(yīng)用端口"),在服務(wù)端的應(yīng)用端口上的私有協(xié)議上處理,一般的協(xié)議是長度 類型 數(shù)據(jù),這樣判斷長度是0x3C70類型0x6C69,單獨(dú)處理這個(gè)消息,但對自己的私有協(xié)議處理還是有影響。
為什么是這樣的長度和類型看圖:


解決方案3:單獨(dú)在服務(wù)應(yīng)用上處理843端口,和其他應(yīng)用的服務(wù)剝離出來:
  1. //安全策略服務(wù)
  2. public void startPolicyServer() throws IOException{
  3. IoAcceptor acceptor = new NioSocketAcceptor();
  4. acceptor.setHandler(new PolicyServerHandler());
  5. acceptor.bind( new InetSocketAddress(843));
  6. System.out.println("安全策略服務(wù)偵聽端口:843");
  7. }
  8. //其他應(yīng)用服務(wù)
  9. ..................
  10. ..................
  11. //單獨(dú)的安全策略處理器
  12. public class PolicyServerHandler extends IoHandlerAdapter {
  13. // 22字節(jié) 0占1個(gè)字節(jié)
  14. String security_quest = "<POLICY-FILE-REQUEST />";
  15. // 最后以0結(jié)尾
  16. String policyStr = "<CROSS-DOMAIN-POLICY>\r\n<ALLOW-ACCESS-FROM to-ports='\"80-9000\"' domain='\"*\"' />\r\n </CROSS-DOMAIN-POLICY>\r\n\0";
  17. private final Logger log = Logger.getLogger(PolicyServerHandler.class.getName());
  18. public void messageReceived(IoSession session, Object message)
  19. throws Exception {
  20. IoBuffer processBuf = (IoBuffer) session.getAttribute("processBuf");
  21. processBuf.put((IoBuffer)message);
  22. processBuf.flip();
  23. if(getRequest(processBuf)){
  24. byte[] reps = policyStr.getBytes("UTF-8");
  25. IoBuffer rb = IoBuffer.allocate(reps.length);
  26. rb.put(reps);//也有putString方法
  27. rb.flip();
  28. session.write(rb);//發(fā)回
  29. log.info("send Policy");
  30. }
  31. }
  32. //獲得安全請求的字符串
  33. private Boolean getRequest(IoBuffer buf){
  34. String req = new String(buf.array());
  35. if (req.indexOf(security_quest) != -1){
  36. return true;
  37. }
  38. return false;
  39. }
  40. @Override
  41. public void messageSent(IoSession session, Object message) throws Exception {
  42. session.close(true);
  43. }
  44. @Override
  45. public void sessionClosed(IoSession session) throws Exception {
  46. super.sessionClosed(session);
  47. session.removeAttribute("processBuf");
  48. }
  49. @Override
  50. public void sessionCreated(IoSession session) throws Exception {
  51. super.sessionCreated(session);
  52. IoBuffer processBuf = IoBuffer.allocate(64);
  53. session.setAttribute("processBuf", processBuf);
  54. }
  55. }

備注:

1 mina2.x對比1.x效率更高,拋棄了原有的btyeBuffer,新寫了Iobuffer,原因如下:
It doesn't provide useful getters and putters such as fill, get/putString, and get/putAsciiInt() enough.
It is difficult to write variable-length data due to its fixed capacity
2 demux下DemuxingProtocolCodecFactory和MessageDecoder等功能更完善了,decodable判斷是否能解析數(shù)據(jù),decode解析實(shí)際的數(shù)據(jù),在處理私有協(xié)議上更簡單了
3 Flash10 socket類新增加timeout屬性指示建立連接時(shí)需等待的毫秒數(shù)

分享:Flash AS3制作火苗動(dòng)畫實(shí)例教程
這個(gè)例子做了有段時(shí)間了.但是也跟那時(shí)候發(fā)的AS2的純代碼火效果是一樣的,也是殘次品. 本次例子沒能做到減少系統(tǒng)資源的能力.剛做完這個(gè)效果以后.也查找了一些粒子方面的資料.看到了很多高人寫的粒子可以使用上千個(gè)粒子卻不占用更多的系統(tǒng)資源,高人.但是,如果能

來源:小寶游戲//所屬分類:Flash教程/更新時(shí)間:2009-04-01
相關(guān)Flash教程