0

我有一个项目要求我将登录数据发布到另一个域。表单提交后,在浏览器中设置 cookie 并重定向用户。

我已经能够使用 javascript 完成此操作,如下所示:

<cfsavecontent variable="headOUT">
     <script type="text/javascript">
          function redirectPost(url, data) {
               var form = document.createElement('form');
               document.body.appendChild(form);
               form.method = 'post';
               form.action = url;
               for (var name in data) {
                    var input = document.createElement('input');
                    input.type = 'hidden';
                    input.name = name;
                    input.value = data[name];
                    form.appendChild(input);
               }
               form.submit();
          }
     </script>
</cfsavecontent>
<cfhtmlhead text="#headOUT#">

<cfset htmlOUT = ''>
<cfset htmlOUT = htmlOUT & '<script type="text/javascript">'>
<cfset htmlOUT = htmlOUT & "redirectPost('#remote_url#', { authen_token: '#encryptedString#' });">
<cfset htmlOUT = htmlOUT & '</script>'>
<cfoutput>#htmlOUT#</cfoutput>

如果我使用cfhttp:

<cfhttp method="Post" url="#remote_url#" RESOLVEURL="Yes">
     <cfhttpparam type="Formfield" name="authen_token" value="#encryptedString#">
</cfhttp>

响应不包含 cookie,它只是带有元重定向的 HTML,就好像我从他们的页面登录一样。但是没有 cookie 我没有通过身份验证。

有没有办法使用 cfhttp 和/或 cflocation 进行重定向和发布,或者 javascript 是最好的解决方案吗?

4

0 回答 0