Ошибка htmlspecialchars при использовании нескольких файлов перевода в laravel - PullRequest
0 голосов
/ 02 марта 2019

В настоящее время я работаю над переводами для моего проекта laravel.Все работает нормально, но только когда я работаю только с одним файлом перевода.

Я пытаюсь все упорядочить, и для этого у меня была идея иметь один файл перевода для боковойширокие компоненты (ссылки для входа / выхода из системы, кнопки возврата и тому подобное), а затем вводите другие файлы перевода для более конкретных вещей, таких как компоненты перевода, найденные на панели управления вашего профиля.

Вот, например, мой английскийфайлы перевода:

general.php

return [
    "login" => "Login",
    "register" => "Register",
    "logout" => "Logout",
    "back" => "Back",
    "postBy" => "Posted by",
    "name" => "Name",
    "email" => "E-Mail Address",
    "pass" => "Password",
    "confirmPass" => "Confirm Password",
    "rememberMe" => "Remember Me", 
    "forgotPass" => "Forgot Your Password?",
];

dashboard.php

<?php

return [
    "title" => "Your Messages",
    "header" => "Message",
    "create" => "Add Message",
    "edit" => "Edit",
    "delete" => "Delete",
];

Я уже получаю ошибки, делаяэто, даже не используя его в моем dashboard.blade.php файле.Я получаю сообщение об ошибке:

ErrorException (E_ERROR) htmlspecialchars () ожидает, что параметр 1 будет строкой, задан массив (представление: C: \ xampp \ htdocs \ messageboard \ resources \ views \ layouts \ app.blade.php) (Просмотр: C: \ xampp \ htdocs \ messageboard \ resources \ views \ layouts \ app.blade.php)

, хотя я даже не пытался вызвать его с чем-токак {{ __('dashboard.title') }}.Я в растерянности относительно причины этой ошибки.

В соответствии с запросом, это представление вызывает ошибку.Я получаю одну и ту же ошибку независимо от того, какая страница загружена, поэтому я предполагаю, что это будет именно это представление, поскольку оно в основном включено и расширено в любом другом представлении.

<!DOCTYPE html>
<html lang="{{ str_replace('_', '-', app()->getLocale()) }}">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <!-- CSRF Token -->
    <meta name="csrf-token" content="{{ csrf_token() }}">

    <title>{{ config('app.name', 'Laravel') }}</title>

    <!-- Scripts -->
    <script src="{{ asset('js/app.js') }}" defer></script>

    <!-- Fonts -->
    <link rel="dns-prefetch" href="//fonts.gstatic.com">
    <link href="https://fonts.googleapis.com/css?family=Nunito" rel="stylesheet" type="text/css">

    <!-- Styles -->
    <link href="{{ asset('css/app.css') }}" rel="stylesheet">
    <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.7.2/css/all.css" integrity="sha384-fnmOCqbTlWIlj8LyTjo7mOUStjsKC4pOpQbqyi7RrhN7udi9RwhKkMHpvLbHG9Sr" crossorigin="anonymous">

</head>
<body>
    <div id="app">
        <nav class="navbar navbar-expand-md navbar-light navbar-laravel">
            <div class="container">
                <a class="navbar-brand" href="{{ url('/') }}">
                    <i class="far fa-envelope"></i>
                    {{ config('app.name', 'Messageboard') }}
                </a>
                <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="{{ __('Toggle navigation') }}">
                    <span class="navbar-toggler-icon"></span>
                </button>

                <div class="collapse navbar-collapse" id="navbarSupportedContent">
                    <!-- Left Side Of Navbar -->
                    <ul class="navbar-nav mr-auto">

                    </ul>

                    <!-- Right Side Of Navbar -->
                    <ul class="navbar-nav ml-auto">
                        <!-- Authentication Links -->
                        @guest
                            <li class="nav-item">
                                <a class="nav-link" href="{{ route('login') }}">{{ __('general.login') }}</a>
                            </li>
                            @if (Route::has('register'))
                                <li class="nav-item">
                                    <a class="nav-link" href="{{ route('register') }}">{{ __('general.register') }}</a>
                                </li>
                            @endif
                        @else
                            <li class="nav-item dropdown">
                                <a id="navbarDropdown" class="nav-link dropdown-toggle" href="#" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" v-pre>
                                    {{ Auth::user()->name }} <span class="caret"></span>
                                </a>

                                <div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarDropdown">
                                    <a class="dropdown-item" href="/dashboard">{{ __('Dashboard') }}</a>
                                    <a class="dropdown-item" href="{{ route('logout') }}"
                                       onclick="event.preventDefault();
                                                     document.getElementById('logout-form').submit();">
                                        {{ __('general.logout') }}
                                    </a>

                                    <form id="logout-form" action="{{ route('logout') }}" method="POST" style="display: none;">
                                        @csrf
                                    </form>
                                </div>
                            </li>
                        @endguest
                    </ul>
                </div>
            </div>
        </nav>

        <div class="container">
            <main class="py-4">
                @include('inc.statusmessages')
                @yield('content')
            </main>
        </div>    
    </div>
</body>
</html>

Контроллер:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Message;
use App\User;
use Auth;

class MessagesController extends Controller
{

    public function __construct(){
        $this->middleware('auth', [
            'except' => [
                'index',
                'show'
            ]
        ]);
    }
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        $messages = Message::orderBy('created_at', 'desc')->get();
        return view('messages')->with('messages', $messages);
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        return view('createmessage');
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        $this->validate($request, [
            'title' => 'required',
            'body' => 'required|min:15|max:500'
        ]);


        // Create Message
        $message = new Message;
        $message->title = $request->input('title');
        $message->body = $request->input('body');
        $message->status = 100;
        $message->user_id = auth()->user()->id;

        $message->save();

        return redirect('/dashboard')->with('success', 'Message Created');
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        $message = Message::findOrFail($id);       
        $user = User::findOrFail($message->user_id); 

        $messageData = [
            'message' => $message,
            'user' => $user
        ];

        return view('showmessage')->with($messageData);
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        $userId = 0;
        $message = Message::findOrFail($id);

        if (Auth::check())
        {
            // The user is logged in...
            $userId = Auth::user()->id;
        }

        if((int)$userId !== (int)$message->user_id) {
            return "Poster ID: ".$message->user_id.", User ID: ".$userId;
        }

        return view('editmessage')->with('message', $message);
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        $this->validate($request, [
            'title' => 'required',
            'body' => 'required|min:15|max:500'
        ]);

        $message = Message::find($id);
        $message->title = $request->input('title');
        $message->body = $request->input('body');
        $message->status = 100;
        $message->user_id = auth()->user()->id;

        $message->save();

        return redirect('/dashboard')->with('success', 'Message Updated');
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        $message = Message::find($id);
        $message->delete();

        return redirect('/dashboard')->with('success', 'Message Removed');
    }
}

Любая помощь будет оценена.Я надеюсь, что я достаточно ясно, и если нет, пожалуйста, дайте мне знать.

1 Ответ

0 голосов
/ 02 марта 2019

Как отметил @Magnus Eriksson, это потому, что вы используете {{ __('Dashboard') }} в своем блейд-представлении , а имеет dashboard.php файл перевода.

Перевод __()Обычно помощник возвращается к возвращаемой строке, когда нет соответствующих ключей перевода, но в этом случае он находит файл перевода.Поскольку вы не используете конкретный ключ из файла, такой как dashboard.title, он возвращает полный массив перевода из файла, который затем присваивается htmlentities() при рендеринге блэйд-представления.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...