0

encodeURIcomponentを使用して、リクエストパラメータの一部としてURLをサーバーに送信しました。

  http://www.regis.edu/regisgpcd.asp?sctn=cpedcn&p1=ap&p2=EDFD&p3=cd3Dcd&_=1332612418587

これはサーバーが見るものです:

http://www.regis.edu/regisgpcd.asp?sctn=cpedcn&p1=ap&p2=EDFD&p3=cd

以前にencodeURIcomponentを使用してデータベースに再度挿入したことがありますが、データベースで見つからないというエラーが発生しました。

このURLは、encodeURIcomponentの後に再度挿入しましたが、以下のような形式になっています。mysqlは、列に挿入する前に通常の種類に変換したと思います。

 http://www.regis.edu/regisgpcd.asp?sctn=cpedcn&p1=ap&p2=EDFD&p3=cd

どうすればその問題を解決できますか?何か案が?

これは私の挿入コードです:

$.ajax({
                    type : "GET",
                    url : '/tree/insertResult/?url=' + encodeURIComponent(url) + '&title=' + encodeURIComponent(title)+'&folder='+folderName+'&snippet='+encodeURIComponent(snippet),
                    cache : false,
                    success : function(res) {
                        if(res == "F")
                            notification("Operation Failed", "You have that bookmark in that folder!");
                        else{   
                            folderName = res;
                            notification("Operation Suceeded", "Bookmark has been created.");
                            updateFolderContent(url, title, folderName, snippet);//it is in _filetree_javascript.html.erb
                        }
                    },
                    error : function(x, y, z) {
                        alert(x.responseText);
                    }
                });
            }

これは私のフェッチコードです:

$.ajax({
                type : "GET",
                url : '/tree/deleteResult/?title='+encodeURIComponent(title)+"&url="+encodeURIComponent(url), 
                cache : false,
                success : function(res) {
                    if(res == "F") //if F is returned from server it means "There is a folder with same name"
                        notification("Operation Failed", "Bookmark cannot be deleted! Sorry :(");   
                    else
                        notification("Operation Succeed", "Bookmark've been deleted.");     
                        deleteResult(domObj);
                },
                error : function(x, y, z) {
                    alert(x.responseText);
                }
            });
        }
4

1 に答える 1

0

サーバー上で文字列をデコードすることで、この問題を解決します。RailsでCGIgemを使用しました

CGI::unescapeHTML(url)
于 2012-03-25T11:00:08.983 に答える