0

開発サーバーに問題があります....ローカルマシンではすべてが機能します....

これが問題です:

次のようなページがあります。

@using Skipstone.Web;
@using Skipstone.Web.Providers;
@using Skipstone.Web.Extensions

@{
    string id = (Request.QueryString["id"] == null) ? ProfileProvider.CurrentUser().UserId : Request.QueryString["id"];
    Profile user = new Profile(id);
    ViewBag.Title = "Profile - " + user.Surname + ", " + user.Forename;
    string credentialId = (user.CredentialId != null && user.CredentialId != "") ? user.CredentialId : "Credential Id";  
}


@if (id != null) {
    <script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>

    <div class="container">
        <div class="row">
            <div class="sixcol">
                <div class="profile">
                    @if (!string.IsNullOrEmpty(user.Photo))
                    {
                        <img src="@user.Photo" />
                    }
                    else
                    {
                        <img src="/Content/media/user.png" />
                    }
                    <h2>@user.Forename @user.Surname</h2>
                    <h3>@user.JobTitle</h3>
                    <p>@HtmlExtensions.decodeEscapedText(user.Bio)</p>
                </div>
            </div>
        </div>
    </div>

    <div class="container">
        <div class="row">
            <div class="sixcol">
                <div class="message"></div>
            </div>
            <div class="sixcol">
            </div>
        </div>
    </div> 

    <div class="container" id="profile-view">
        <div class="row">
            <div class="sixcol">
                <div class="profile form">
                    @if (id == ProfileProvider.CurrentUser().UserId)
                    {
                        <a href="#" class="button edit small" style="float: right;">Edit</a>
                    }
                    <ul>
                        @if (user.Telephone != null && user.Telephone != "")
                        { <li class="profile-tel"><span class="icon"></span><span>@user.Telephone</span></li> }
                        @if (user.Mobile != null && user.Mobile != "")
                        { <li class="profile-mob"><span class="icon"></span><span>@user.Mobile</span></li> }
                        @if (user.Email != null && user.Email != "")
                        { <li class="profile-email"><span class="icon"></span><span><a href="mailto:@user.Email">@user.Email</a></span></li> }
                    </ul>
                    <ul>
                        @if (user.Twitter != null && user.Twitter != "")
                        { <li class="profile-twitter"><span class="icon"></span><span><a href="mailto:@user.Twitter">@user.Twitter</a></span></li> }
                        @if (user.Facebook != null && user.Facebook != "")
                        { <li class="profile-facebook"><span class="icon"></span><span><a href="mailto:@user.Facebook">@user.Facebook</a></span></li> }
                        @if (user.LinkedIn != null && user.LinkedIn != "")
                        { <li class="profile-linked"><span class="icon"></span><span><a href="mailto:@user.LinkedIn">@user.LinkedIn</a></span></li> }
                    </ul>
                </div>
            </div>
            <div class="sixcol"></div>
        </div>
    </div> 

    <form id="profile-edit" style="display: none;">
        <div class="container">
            <div class="row">
                <div class="sixcol">
                    <div class="form form-top form-bottom">                    
                        <input type="hidden" id="UserId" name="UserId" value="@user.UserId" />
                        <input type="hidden" id="CompanyName" name="CompanyName" value="@user.CompanyName" />
                        <input type="hidden" id="Photo" name="Photo" value="@user.Photo" />
                        <input type="hidden" id="UserCanEdit" name="UserCanEdit" value="@user.UserCanEdit" />
                        <input type="hidden" id="UserCanEditOwn" name="UserCanEditOwn" value="@user.UserCanEditOwn" />
                        <input type="hidden" id="UserCanApprove" name="UserCanApprove" value="@user.UserCanApprove" />
                        <input type="hidden" id="UserRequiresApproval" name="UserRequiresApproval" value="@user.UserRequiresApproval" />

                        <label class="block-label" for="Title">Title</label>
                        <div class="textbox"><input type="text" class="required" name="Title" id="Title" value="@user.Title" /></div>

                        <label class="block-label" for="Forname">Forname(s)</label>
                        <div class="textbox"><input type="text" class="required" name="Forename" id="Forename" value="@user.Forename" /></div>

                        <label class="block-label" for="Surname">Surname</label>
                        <div class="textbox"><input type="text" class="required" name="Surname" id="Surname" value="@user.Surname" /></div>

                        <label class="block-label" for="UserName">Username</label>
                        <div class="textbox"><input type="text" class="required" id="UserName" name="UserName" value="@user.UserName" /></div>

                        <label class="block-label" for="file">Upload profile image</label>
                        <div class="textbox file"><input type="file" id="file" name="file" /></div>

                        <label class="block-label" for="JobTitle">Job title</label>
                        <div class="textbox"><input type="text" name="JobTitle" id="JobTitle" value="@user.JobTitle" /></div>

                        <label class="block-label" for="Telephone">Telephone</label>
                        <div class="textbox"><input type="text" name="Telephone" id="Telephone" value="@user.Telephone" /></div>

                        <label class="block-label" for="Mobile">Mobile</label>
                        <div class="textbox"><input type="text" name="Mobile" id="Mobile" value="@user.Mobile" /></div>

                        <label class="block-label" for="Email">Email address</label>
                        <div class="textbox"><input type="text" class="required" name="Email" id="Email" value="@user.Email" /></div>

                        @if (SettingsProvider.CurrentSiteSettings().TwoFactorAuthentication)
                        { 
                            <label class="block-label" for="CredentialId">Credential Id</label>  
                            <div class="textbox"><input type="text" class="required" id="CredentialId" name="CredentialId" value="@user.CredentialId" /></div>
                            <input type="hidden" class="required" name="Code" value="Security Code" />
                        }
                        else
                        {
                            <input type="hidden" class="required" name="CredentialId" value="@credentialId" />
                            <input type="hidden" class="required" name="Code" value="Security Code" />
                        }   

                        <label class="block-label" for="LinkedIn">LinkedIn</label>
                        <div class="textbox"><input type="text" name="LinkedIn" id="LinkedIn" value="@user.LinkedIn" /></div>

                        <label class="block-label" for="Twitter">Twitter</label>
                        <div class="textbox"><input type="text" name="Twitter" id="Twitter" value="@user.Twitter" /></div>

                        <label class="block-label" for="Facebook">Facebook</label>
                        <div class="textbox"><input type="text" name="Facebook" id="Facebook" value="@user.Facebook" /></div>

                        <label class="block-label" for="Bio">Bio</label>
                        <div class="textbox"><textarea id="Bio" name="Bio" rows="9">@user.Bio</textarea></div>

                        <div class="action">
                            <button>Save</button>
                        </div>
                        <button id="cancel">Cancel</button>
                    </div>
                </div>
            </div>
        </div>
    </form>

    <script src="@Url.Content("~/Scripts/jquery.skipstone-profile-save.js")" type="text/javascript"></script>
}
else
{
    throw new Exception("Invalid id specified.");
}

今、私は問題を抱えています....

/Profile (現在のユーザーのフィールドを表示し、正常に動作します)

/Profile?id=4 (Guid には 4 つのダッシュ (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx) を含む 32 桁を含める必要があることを示します)

/Profile?id=E23CB58D-BDBC-4BE5-A27C-7E6518ED72B0 (404 エラーが表示されます...)

Guid が機能しない理由がわかりません。私が言ったように、これは私のローカル マシンでは機能しますが、開発サーバーでは機能しません。GUID文字列を受け入れるページは機能しないことを指摘しておく必要があります.それらはすべてプロファイルページと同じことを行います....

なぜこれが起こっているのか誰にも分かりますか?

アップデート

コードを次のように変更しました

@{
    string id = Request.QueryString["id"];  
}

@id

そして、私はまだ問題を抱えています

更新 2

コードを次のように変更しました。

@{
    string id = (Request.QueryString["UserId"] == null) ? ProfileProvider.CurrentUser().UserId : Convert.ToString(Request.QueryString["UserId"]);
    Profile user = new Profile(id);
    ViewBag.Title = "Profile - " + user.Surname + ", " + user.Forename;
    string credentialId = (user.CredentialId != null && user.CredentialId != "") ? user.CredentialId : "Credential Id";  
}

Id/id をパラメーターとして使用しようとすると問題になる可能性があると考えたためです。とにかく、私はまだ同じ問題を抱えています....

4

2 に答える 2

1

私はそれを考え出した。これは、Web.config のこれが原因でした。

<requestLimits maxAllowedContentLength="1048576000" maxUrl="260" maxQueryString="25" />

それは maxQueryString でした。

それ以来、maxUrl と maxQueryString の両方を削除しましたが、現在はすべて機能しています:)

于 2013-05-17T22:06:06.390 に答える