无法加载资源:服务器响应状态为 500(内部服务器错误)动态 api

Failed to load resource: the server responded with a status of 500 (Internal Server Error) dynamic api

已下载最新 (3.0) 样板,零。

在 codeproject.com

跟进了任务创建者应用程序的实施

我添加了简单实体(客户端)而不是任务。

任务显示正常。但是,当我尝试添加新客户端时,似乎动态 api 不可用并且出现以下错误:

客户端控制器:

`[AbpMvcAuthorize] public class 客户端控制器:MyAppControllerBase { 私人只读 IClientAppService _clientService;

    public ClientsController(IClientAppService clientService)
    {
        _clientService = clientService;
    }

    public async Task<ViewResult> Index(GetAllClientsInput input)
    {
        var output = await _clientService.GetAll(input);
        var model = new Web.Models.Clients.IndexViewModel(output.Items);
        return View("Index", model);

    }

    public async Task Create(CreateClientInput input)
    {
        await _clientService.Create(input);
    }

    public async Task Delete(CreateClientInput input)
    {
        await _clientService.Create(input);
    }
}` 

Index.js:

(function() {
    $(function() {

        var _clientService = abp.services.app.client;
        var _$modal = $('#ClientCreateModal');
        var _$form = _$modal.find('form');

        _$form.validate();

        _$form.find('button[type="submit"]').click(function (e) {
            e.preventDefault();

            if (!_$form.valid()) {
                return;
            }

            var client = _$form.serializeFormToObject(); //serializeFormToObject is defined in main.js

            abp.ui.setBusy(_$modal);
            _clientService.create(client).done(function () {
                _$modal.modal('hide');
                location.reload(true); //reload page to see new user!
            }).always(function () {
                abp.ui.clearBusy(_$modal);
            });
        });

        _$modal.on('shown.bs.modal', function () {
            _$modal.find('input:not([type=hidden]):first').focus();
        });
    });
})();

Index.cshtml

@section scripts
{
    <environment names="Development">
        <script src="~/js/views/clients/Index.js" asp-append-version="true"></script>
    </environment>

    <environment names="Staging,Production">
        <script src="~/js/views/clients/Index.min.js" asp-append-version="true"></script>
    </environment>
}
<div class="row clearfix">
    <div class="col-lg-12 col-md-12 col-sm-12 col-xs-12">
        <div class="card">
            <div class="header">
                <h2>
                    @L("Clients")
                </h2>
                <ul class="header-dropdown m-r--5">
                    <li class="dropdown">
                        <a href="javascript:void(0);" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">
                            <i class="material-icons">more_vert</i>
                        </a>
                        <ul class="dropdown-menu pull-right">
                            <li><a href="javascript:void(0);" class=" waves-effect waves-block">Action</a></li>
                            <li><a href="javascript:void(0);" class=" waves-effect waves-block">Another action</a></li>
                            <li><a href="javascript:void(0);" class=" waves-effect waves-block">Something else here</a></li>
                        </ul>
                    </li>
                </ul>
            </div>
            <div class="body table-responsive">
                <table class="table">
                    <thead>
                    <tr>
                        <th>@L("UserName")</th>
                        <th>@L("FullName")</th>
                        <th>@L("EmailAddress")</th>
                        <th>@L("IsActive")</th>
                    </tr>
                    </thead>
                    <tbody>
                    @foreach (var user in Model.Clients)
                    {
                        <tr>
                            <td>@user.FirstName</td>
                            <td>@user.LastName</td>
                            <td>@user.Email</td>
                            <td>@user.Mobile</td>
                        </tr>
                    }
                    </tbody>
                </table>
                <button type="button" class="btn btn-primary btn-circle waves-effect waves-circle waves-float pull-right" data-toggle="modal" data-target="#ClientCreateModal">
                    <i class="material-icons">add</i>
                </button>
            </div>
        </div>
    </div>
</div>
<div class="modal fade" id="ClientCreateModal" tabindex="-1" role="dialog" aria-labelledby="ClientCreateModalLabel" data-backdrop="static">
    <div class="modal-dialog" role="document">
        <div class="modal-content">
            <form name="userCreateForm" role="form" novalidate class="form-validation">
                <div class="modal-header">
                    <h4 class="modal-title">
                        <span>@L("CreateNewClient")</span>
                    </h4>
                </div>
                <div class="modal-body">
                    <div class="form-group form-float">
                        <div class="form-line">
                            <input class="form-control" type="text" name="FirstName" required maxlength="@AbpUserBase.MaxUserNameLength" minlength="2">
                            <label class="form-label">@L("FirstName")</label>
                        </div>
                    </div>
                    <div class="form-group form-float">
                        <div class="form-line">
                            <input type="text" name="LastName" class="form-control" required maxlength="@AbpUserBase.MaxNameLength">
                            <label class="form-label">@L("LastName")</label>
                        </div>
                    </div>
                    <div class="form-group form-float">
                        <div class="form-line">
                            <input type="text" name="Mobile" class="form-control" required maxlength="@AbpUserBase.MaxSurnameLength">
                            <label class="form-label">@L("Mobile")</label>
                        </div>
                    </div>
                    <div class="form-group form-float">
                        <div class="form-line">
                            <input type="email" name="Email" class="form-control" required maxlength="@AbpUserBase.MaxEmailAddressLength">
                            <label class="form-label">@L("Email")</label>
                        </div>
                    </div>
                </div>
                <div class="modal-footer">
                    <button type="button" class="btn btn-default waves-effect" data-dismiss="modal">@L("Cancel")</button>
                    <button type="submit" class="btn btn-primary waves-effect">@L("Save")</button>
                </div>
            </form>
        </div>
    </div>
</div>

客服:

[AbpAuthorize(PermissionNames.Pages_Tenants)]
public class ClientAppService : ApplicationService, IClientAppService
{
    private readonly IRepository<Client> _clientRepository;

    public ClientAppService(IRepository<Client> clientRepository)
    {
        _clientRepository = clientRepository;
    }

    public async Task<ListResultDto<ClientListDto>> GetAll(GetAllClientsInput input)
    {
        var clients = await _clientRepository
            .GetAll().ToListAsync<Client>();

        return new ListResultDto<ClientListDto>(
            ObjectMapper.Map<List<ClientListDto>>(clients));
    }

    public async Task Create(CreateClientInput input)
    {
        var task = ObjectMapper.Map<Client>(input);
        await _clientRepository.InsertAsync(task);
    }
}

服务器在创建操作时完全没有受到攻击。

知道我错过了什么吗?

我认为对 IMustHaveTenant 界面存在误解。当您从 IMustHaveTenant 派生实体时,您不能在宿主环境中使用该实体。主机没有租户 ID。据我了解,客户属于租户。所以你要做的是,从主机菜单中删除客户端页面。什么时候想见租户的客户,就用冒充吧。

对于 show/hide 特定的菜单项,您可以使用 requiredPermissionName。可以将权限配置为仅用于 tenants/host/both。因此,创建一个新的权限,配置为供租户使用。在为客户页面创建新的 MenuItemDefinition 时设置该权限。就是这样!

阅读 => https://aspnetboilerplate.com/Pages/Documents/Navigation?searchKey=navigation#registering-navigation-provider