यदि केवल url एन्कोडिंग के साथ सौदा किया जाता है, तो मुझे EscapeUriString का उपयोग करना चाहिए ?
यदि केवल url एन्कोडिंग के साथ सौदा किया जाता है, तो मुझे EscapeUriString का उपयोग करना चाहिए ?
जवाबों:
EscapeDataString
हमेशा उपयोग करें (क्यों के बारे में अधिक जानकारी के लिए, Livven का जवाब नीचे देखें)
संपादित करें : दोनों को एन्कोडिंग पर अलग करने के लिए मृत लिंक को हटा दिया गया
URLEncode
नहीं) भी (तुलना करने के लिए)।
मुझे मौजूदा उत्तर संतोषजनक नहीं लगे इसलिए मैंने इस मुद्दे को हल करने के लिए थोड़ा गहरा खुदाई करने का फैसला किया। हैरानी की बात है, जवाब बहुत आसान है:
वहाँ (लगभग *) कोई वैध कारण कभी उपयोग करने के लिए है Uri.EscapeUriString
। यदि आपको किसी स्ट्रिंग को प्रतिशत-एनकोड करने की आवश्यकता है, तो हमेशा उपयोग करें Uri.EscapeDataString
।
* वैध उपयोग के मामले के लिए अंतिम पैराग्राफ देखें।
ऐसा क्यों है? प्रलेखन के अनुसार :
Unricaped URI स्ट्रिंग को Uri कंस्ट्रक्टर के पैरामीटर के रूप में तैयार करने के लिए EscapeUriString विधि का उपयोग करें।
यह वास्तव में मतलब नहीं है। RFC 2396 के अनुसार :
एक यूआरआई हमेशा "बच गए" रूप में होता है, क्योंकि एक पूर्ण किए गए यूआरआई से बचने या बाहर निकलने से उसका शब्दार्थ बदल सकता है।
जबकि RFC 3986 द्वारा उद्धृत RFC को मान लिया गया है , बिंदु अभी भी खड़ा है। आइए कुछ ठोस उदाहरणों को देखकर इसे सत्यापित करें:
आपके पास एक सरल URI है, जैसे:
http://example.org/
Uri.EscapeUriString
इसे बदल नहीं सकते।
आप भागने के संबंध में क्वेरी स्ट्रिंग को मैन्युअल रूप से संपादित करने का निर्णय लेते हैं:
http://example.org/?key=two words
Uri.EscapeUriString
(सही ढंग से) आप के लिए जगह से बच जाएगा:
http://example.org/?key=two%20words
आप आगे भी क्वेरी स्ट्रिंग को मैन्युअल रूप से संपादित करने का निर्णय लेते हैं:
http://example.org/?parameter=father&son
हालाँकि, यह स्ट्रिंग द्वारा परिवर्तित नहीं किया गया है Uri.EscapeUriString
, क्योंकि यह मानता है कि एम्परसैंड एक अन्य कुंजी-मूल्य जोड़ी की शुरुआत का प्रतीक है। यह हो सकता है या आप का इरादा नहीं हो सकता है।
आप तय करते हैं कि आप वास्तव में key
पैरामीटर चाहते हैं father&son
, इसलिए आप एम्परसेंड से बचकर पिछले URL को मैन्युअल रूप से ठीक करते हैं:
http://example.org/?parameter=father%26son
हालांकि, Uri.EscapeUriString
प्रतिशत चरित्र से भी बच जाएगा, एक दोहरे एन्कोडिंग के लिए अग्रणी:
http://example.org/?parameter=father%2526son
जैसा कि आप देख सकते हैं, Uri.EscapeUriString
अपने इच्छित उद्देश्य के लिए उपयोग करना &
कई कुंजी-मूल्य जोड़े के बीच विभाजक के रूप में क्वेरी स्ट्रिंग में कुंजी या मान के भाग के रूप में उपयोग करना असंभव बनाता है ।
ऐसा इसलिए है, क्योंकि यह पूर्ण यूआरआई से बचने के लिए उपयुक्त बनाने के प्रयास में, यह आरक्षित वर्णों की उपेक्षा करता है और केवल उन वर्णों से बचता है जो न तो आरक्षित हैं और न ही अनारक्षित हैं, जो कि, BTW, प्रलेखन के विपरीत है । इस तरह आप कुछ के साथ समाप्त नहीं करते हैं http%3A%2F%2Fexample.org%2F
, लेकिन आप ऊपर वर्णित मुद्दों के साथ समाप्त करते हैं।
अंत में, यदि आपका यूआरआई वैध है, तो इसे उरी बाधा के पैरामीटर के रूप में पारित होने से बचने की आवश्यकता नहीं है, और यदि यह मान्य नहीं है, तो कॉलिंग Uri.EscapeUriString
एक जादू समाधान भी नहीं है। वास्तव में, यह कई मामलों में काम करेगा यदि अधिकांश मामले नहीं हैं, लेकिन यह विश्वसनीय तरीकों से नहीं है।
आपको हमेशा कुंजी-मूल्य जोड़े और प्रतिशत-एन्कोडिंग को इकट्ठा करके और फिर आवश्यक विभाजकों के साथ उन्हें सम्मिलित करके अपने URL और क्वेरी स्ट्रिंग का निर्माण करना चाहिए। आप Uri.EscapeDataString
इस उद्देश्य के लिए उपयोग कर सकते हैं , लेकिन नहीं Uri.EscapeUriString
, क्योंकि यह आरक्षित वर्णों से नहीं बचता है, जैसा कि ऊपर बताया गया है।
केवल अगर आप ऐसा नहीं कर सकते हैं, उदाहरण के लिए जब उपयोगकर्ता द्वारा प्रदान किए गए यूआरआई के साथ काम करते हैं, तो क्या यह Uri.EscapeUriString
अंतिम उपाय के रूप में उपयोग करने के लिए समझ में आता है । लेकिन पहले उल्लिखित कैविएट लागू होते हैं - यदि उपयोगकर्ता द्वारा प्रदान किया गया यूआरआई अस्पष्ट है, तो परिणाम वांछनीय नहीं हो सकते हैं।
encodeURI
/ Uri.EscapeUriString
की जरूरत नहीं है जितनी बार encodeURIComponent
/ Uri.EscapeDataString
(जब से आप अंधे उर के साथ बहरे हो रहे हैं जो कि उरई संदर्भ में उपयोग किया जाना चाहिए), लेकिन इसका मतलब यह नहीं है कि इसका स्थान नहीं है।
प्लस (+) वर्ण इन विधियों के बीच अंतर के बारे में बहुत कुछ बता सकते हैं। एक साधारण यूआरआई में, प्लस वर्ण का अर्थ "स्पेस" है। "खुश बिल्ली" के लिए Google को क्वेरी करने पर विचार करें:
यह एक वैध यूआरआई है (इसे आज़माएं), और EscapeUriString
इसे संशोधित नहीं करेंगे।
अब "खुश c ++" के लिए Google पर विचार करें:
यह एक वैध यूआरआई है (इसे आज़माएं), लेकिन यह "खुश ग" के लिए एक खोज का उत्पादन करता है, क्योंकि दो प्लसस को रिक्त स्थान के रूप में व्याख्या की जाती है। इसे ठीक करने के लिए, हम "happy c ++" को EscapeDataString
वॉयस * पास कर सकते हैं :
*) एन्कोडेड डेटा स्ट्रिंग वास्तव में "खुश% 20c% 2B% 2B" है; अंतरिक्ष वर्ण के लिए% 20 हेक्स है, और प्लस वर्ण के लिए% 2B हेक्स है।
यदि आप उपयोग कर रहे हैं UriBuilder
जैसा कि आपको होना चाहिए, तो आपको केवल EscapeDataString
अपने संपूर्ण यूआरआई के कुछ घटकों को ठीक से बचाना होगा। @ इस सवाल का लिवेन का जवाब आगे साबित करता है कि वास्तव में उपयोग करने का कोई कारण नहीं है EscapeUriString
।
"https://www.google.com/?q=happy c++"
। ऐसा लगता है कि मुझे मैन्युअल रूप से "?" पर विभाजित होने की आवश्यकता है, या क्या कोई बेहतर तरीका है?
EscapeDataString
। यदि आपके द्वारा प्रदान किया गया URL वास्तविक URL है, तो हाँ आप बस विभाजित करना चाहते हैं ?
।
स्रोत में टिप्पणियाँ स्पष्ट रूप से अंतर को संबोधित करती हैं। यह जानकारी XML दस्तावेज़ टिप्पणियों के माध्यम से आगे क्यों नहीं लाई गई यह मेरे लिए एक रहस्य है।
EscapeUriString:
यह विधि किसी भी वर्ण से बच जाएगी जो कि प्रतिशत संकेत सहित आरक्षित या अनारक्षित चरित्र नहीं है। ध्यान दें कि EscapeUriString भी '#' चिन्ह से बच नहीं पाएगा।
EscapeDataString:
यह विधि किसी भी वर्ण से बच जाएगी जो कि एक अनारक्षित चरित्र नहीं है, जिसमें प्रतिशत संकेत शामिल हैं।
इसलिए अंतर यह है कि वे आरक्षित वर्णों को कैसे संभालते हैं । EscapeDataString
उनसे बच जाता है; EscapeUriString
नहीं करता।
RFC के अनुसार , आरक्षित वर्ण हैं::/?#[]@!$&'()*+,;=
पूर्णता के लिए, अनारक्षित वर्ण अल्फ़ान्यूमेरिक हैं और -._~
दोनों विधियां ऐसे पात्रों से बचती हैं जो न तो आरक्षित हैं और न ही अनारक्षित।
मैं सामान्य धारणा से असहमत हूं जो EscapeUriString
बुराई है। मुझे लगता है कि एक विधि जो केवल अवैध पात्रों (जैसे रिक्त स्थान) से बचती है और आरक्षित वर्ण उपयोगी नहीं है। लेकिन इसमें एक विचित्रता है कि यह %
चरित्र को कैसे संभालता है । प्रतिशत-एन्कोडेड वर्ण ( %
उसके बाद 2 हेक्स अंक) एक URI में कानूनी हैं । मुझे लगता है कि EscapeUriString
अगर यह इस पैटर्न का पता लगाता और %
इसे 2 हेक्स अंकों से तुरंत आगे ले जाता तो एन्कोडिंग से बचने के लिए यह कहीं अधिक उपयोगी होता ।
एक सरल उदाहरण
var data = "example.com/abc?DEF=あいう\x20えお";
Console.WriteLine(Uri.EscapeUriString(data));
Console.WriteLine(Uri.EscapeDataString(data));
Console.WriteLine(System.Net.WebUtility.UrlEncode(data));
Console.WriteLine(System.Web.HttpUtility.UrlEncode(data));
/*
=>
example.com/abc?DEF=%E3%81%82%E3%81%84%E3%81%86%20%E3%81%88%E3%81%8A
example.com%2Fabc%3FDEF%3D%E3%81%82%E3%81%84%E3%81%86%20%E3%81%88%E3%81%8A
example.com%2Fabc%3FDEF%3D%E3%81%82%E3%81%84%E3%81%86+%E3%81%88%E3%81%8A
example.com%2fabc%3fDEF%3d%e3%81%82%e3%81%84%e3%81%86+%e3%81%88%e3%81%8a
*/
Uri.EscapeDataString()
जाएं। अन्य दृष्टिकोणों के साथ, सिस्टम में हर संभव इनपुट के लिए इच्छित परिणाम का उत्पादन करने के लिए पर्याप्त जानकारी नहीं होती है।