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 再次将它插入到数据库中,但我收到了一个错误,即在数据库中找不到它。

尽管我在 encodeURIcomponent 之后再次插入了该 url,但格式如下所示。我猜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中使用了CGI gem

CGI::unescapeHTML(url)
于 2012-03-25T11:00:08.983 回答