redaelfillali/laravel-secure-model 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

redaelfillali/laravel-secure-model

最新稳定版本:1.1.0

Composer 安装命令:

composer require redaelfillali/laravel-secure-model

包简介

Eloquent base model with auto-sanitized getters and setters.

README 文档

README

Latest Version on Packagist PHP Version Laravel Version License: MIT

An Eloquent base model that automatically sanitizes specified attributes on get and set, protecting your application from XSS vulnerabilities out of the box.

Features

  • Automatically purifies HTML on both read (getAttribute) and write (setAttribute)
  • Powered by stevebauman/purify (HTMLPurifier wrapper)
  • Zero-configuration: just list the attributes to sanitize
  • Supports Laravel 9, 10, 11, 12, and 13
  • Supports PHP 8.1, 8.2, 8.3, and 8.4

Requirements

Dependency Version
PHP ^8.1 | ^8.2 | ^8.3 | ^8.4
Laravel ^9.0 | ^10.0 | ^11.0 | ^12.0 | ^13.0
stevebauman/purify ^6.3

Installation

composer require redaelfillali/laravel-secure-model

The service provider is registered automatically via Laravel's package auto-discovery.

Optionally publish the Purify configuration to customise the HTML rules:

php artisan vendor:publish --provider="Stevebauman\Purify\PurifyServiceProvider"

Usage

Extend SecureModel instead of the default Eloquent Model and declare the attributes you want automatically sanitized in the $sanitizeAttributes array:

<?php

use Redaelfillali\LaravelSecureModel\SecureModel;

class Post extends SecureModel
{
    // These attributes will be purified on every get and set
    protected array $sanitizeAttributes = ['title', 'body', 'excerpt'];
}

That's it — any XSS payloads stored in or read from the listed attributes will be stripped automatically:

$post = new Post();
$post->body = '<p>Hello</p><script>alert("xss")</script>';

// The <script> tag is stripped; safe HTML is preserved.
echo $post->body; // <p>Hello</p>

Attributes not listed in $sanitizeAttributes are left completely untouched, so only the fields you care about are affected.

How it works

SecureModel overrides two Eloquent methods:

Method Behaviour
setAttribute($key, $value) Sanitizes the value before it is stored in the model's attribute bag
getAttribute($key) Sanitizes the value when it is retrieved from the model

Only attributes listed in $sanitizeAttributes and whose value is a string are passed through Purify::clean(). All other types (int, null, arrays …) are returned as-is.

Testing

composer test

Tests are written with Pest and use Orchestra Testbench for a full in-process Laravel environment.

License

The MIT License (MIT). See LICENSE for details.

统计信息

  • 总下载量: 297
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-04-22

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固