在生产环境中测试,无水印。
随时随地满足您的需求。
获得30天的全功能产品。
几分钟内就能启动并运行。
在您的产品试用期间,全面访问我们的支持工程团队。
在现代网络应用中,确保数据安全和隐私至关重要。 保护数据库ID或URL等敏感信息的一种有效方法是使用Hashids,这是一种JavaScript加密库,可以将数字数据转换为唯一的、可逆的加密哈希。 本文将探讨如何将 Hashids 无缝集成到 React 应用程序中,以混淆和解码标识符。
Hashids 是一个小巧但功能强大的库,可将数字数据转换为散列字符串。 主要目标是模糊数字标识符,防止敏感信息泄露。 这种转换是可逆的,允许在需要时检索原始数字数据。 Hashids 是一个 JavaScript 库,用于从数字中生成类似于 YouTube 的 ID,对敏感数据进行编码,或安全地向用户公开数据库 ID,或只是混淆数字中的 ID。
要将 Hashids 集成到您的 React 应用程序中,请按照以下步骤操作:
首先,在 React 项目中通过 npm 安装 Hashids:
npm install hashids
or 
yarn add hashidsnpm install hashids
or 
yarn add hashids在 React 组件或实用程序文件中,用盐和可选的最小哈希长度初始化一个新的 Hashids 实例:
import { useState, useEffect } from 'react';
import Hashids from 'hashids';
const MyComponent = () => {
  const [hashids, setHashids] = useState(null);
  useEffect(() => {
    const initHashids = new Hashids('your_salt_here', 8); // Replace 'your_salt_here' with your actual salt or configure custom alphabet
    setHashids(initHashids);
  }, []);
  // Other component logic here
  return (
    <div>
      {/* Your JSX content */}
    </div>
  );
};
export default MyComponent;js将`'your_salt_here'`替换为您用于自定义哈希输出的唯一字符串(盐)。
初始化后,您可以使用 Hashids 对数字数据进行编码和解码。 例如,对数据库 ID 进行编码:
const encodedId = hashids.encode(12345); // Example: 'B0zGbvA9' non sequential idsjs并解码回原始 ID:
const decodedIds = hashids.decode('B0zGbvA9'); // Example: [12345]js必要时在 React 组件中集成 Hashids。 例如,将散列 ID 作为道具传递:
const MyComponent = ({ id }) => {
  const encodedId = hashids ? hashids.encode(id) : '';
  return (
    <div>
      <p>Encoded ID: {encodedId}</p>
      {/* Other JSX content */}
    </div>
  );
};jsIronPDF for Node.js 是来自Iron Software的强大Node.js PDF库,使开发人员能够在其.NET项目中生成和编辑PDF。 无论您需要从 HTML 创建 PDF、处理现有 PDF 还是将网页转换为 PDF 格式,IronPDF 都能满足您的需求。

将 HTML 内容轻松转换为 PDF 文档。 此功能特别适用于从网页内容生成动态PDF。
直接从 URL 生成 PDF,允许您捕获网页内容并以编程方式将其保存为 PDF 文件。
轻松合并、拆分和操作现有的PDF文档。 IronPdf 提供附加页面、分割文档等功能。
通过设置密码或应用数字签名来保护您的PDF文档。 IronPDF 提供选项以保护您的敏感文档免受未经授权的访问。
生成高质量的PDF文档,精确渲染文本、图像和格式。 IronPDF 确保您生成的 PDF 保持与原始内容的一致性。
IronPDF 兼容多个平台,包括 Windows、Linux 和 macOS,因此适用于各种开发环境。
使用其npm软件包轻松将IronPDF集成到您的Node.js应用程序中。 API 文档详实,使将 PDF 生成功能集成到您的项目中变得简单明了。
要安装 IronPDF NPM 包,请使用以下命令:
yarn add @ironsoftware/ironpdf @ironsoftware/ironpdf-engine-windows-x64yarn add @ironsoftware/ironpdf @ironsoftware/ironpdf-engine-windows-x64安装依赖项:首先,使用以下命令创建一个新的 Next.js 项目(如果您还没有创建):请参阅此处
npx create-next-app@latest hashids-pdf --use-npm --example "https://github.com/vercel/next-learn/tree/main/basics/learn-starter"npx create-next-app@latest hashids-pdf --use-npm --example "https://github.com/vercel/next-learn/tree/main/basics/learn-starter"接下来,导航到你的项目目录:
cd hashids-pdfcd hashids-pdf安装所需的软件包:
yarn add @ironsoftware/ironpdf @ironsoftware/ironpdf-engine-windows-x64
yarn add hashidsyarn add @ironsoftware/ironpdf @ironsoftware/ironpdf-engine-windows-x64
yarn add hashids现在,让我们创建一个使用IronPDF生成PDF的简单示例。 在你的 Next.js 组件中(例如,pages/index.tsx),添加以下代码:
PDF 生成 API:第一步是创建一个用于生成 PDF 文档的后端 API。 由于 IronPdf 只在服务器端运行,我们需要创建一个 API,以便在用户想要生成 PDF 时调用。 在 pages/api/pdf.js 路径下创建一个文件,并添加以下内容。
IronPDF需要一个许可证密钥,您可以从许可证页面获取,并将其放入以下代码中。
// pages/api/pdf.js
import {IronPdfGlobalConfig, PdfDocument} from "@ironsoftware/ironpdf";
// Apply your IronPDF license key
IronPdfGlobalConfig.getConfig().licenseKey = "Your license key";
export default async function handler(req, res) {
  try {
    const initHashids = new Hashids('IronPDF Is Awesome and this is the salt', 8); 
    const f = req.query.f;
    const l = initHashids.encode(f);
    let content = "<h1>Demo Hashids and Generate PDF Using IronPDF</h1>"
    content+="<p>Input:"+f+"</p>";
    content+="<p>HashID:"+l+"</p>";
    const pdf = await PdfDocument.fromHtml(content);
    const data = await pdf.saveAsBuffer();
    console.error("data PDF:", data);
    res.setHeader("Content-Type", "application/pdf");
    res.setHeader(
      "Content-Disposition",
      "attachment; filename=awesomeIron.pdf",
    );
    res.send(data);
  } catch (error) {
    console.error("Error generating PDF:", error);
    res.status(500).end();
  }
}js现在修改 index.js 代码如下,以使用 hashID 和 IronPdf
import Head from "next/head";
import styles from "../styles/Home.module.css";
import React, { useState, useEffect } from "react";
import Hashids from 'hashids';
export default function Home() {
  const [text, setText] = useState("");
  const [etext, seteText] = useState("");
  const [hashids, setHashids] = useState(null);
  useEffect(() => {
    const initHashids = new Hashids('IronPDF Is Awesome and this is the salt', 8); 
    setHashids(initHashids);
  }, []);
  const generatePdf = async () => {
    try {
      const response = await fetch("/api/pdf-hash?f=" + text);
      const blob = await response.blob();
      const url = window.URL.createObjectURL(new Blob([blob]));
      const link = document.createElement("a");
      link.href = url;
      link.setAttribute("download", "awesomeIron.pdf");
      document.body.appendChild(link);
      link.click();
      link.parentNode.removeChild(link);
    } catch (error) {
      console.error("Error generating PDF:", error);
    }
  };  
  const handleChange = (event) => {
    seteText(hashids.encode(event.target.value));
    setText(event.target.value);
  };
  return (
    <div className={styles.container}>
      <Head>
        <title>Generate PDF Using IronPDF</title>
        <link rel="icon" href="/favicon.ico" />
      </Head>
      <main>
        <h1>Demo Hashids and Generate PDF Using IronPDF</h1>
        <p>
          <span>Enter Url To get Hashids and Convert to PDF:</span>{" "}
        </p>
        <p>
          HashID of input: {etext}
        </p>        
        <button style={{ margin: 20, padding: 5 }} onClick={generatePdf}>
          Generate PDF 
        </button>
      </main>
      <style jsx>{`
        main {
          padding: 5rem 0;
          flex: 1;
          display: flex;
          flex-direction: column;
          justify-content: center;
          align-items: center;
        }
        footer {
          width: 100%;
          height: 100px;
          border-top: 1px solid #eaeaea;
          display: flex;
          justify-content: center;
          align-items: center;
        }
        footer img {
          margin-left: 0.5rem;
        }
        footer a {
          display: flex;
          justify-content: center;
          align-items: center;
          text-decoration: none;
          color: inherit;
        }
        code {
          background: #fafafa;
          border-radius: 5px;
          padding: 0.75rem;
          font-size: 1.1rem;
          font-family:
            Menlo,
            Monaco,
            Lucida Console,
            Liberation Mono,
            DejaVu Sans Mono,
            Bitstream Vera Sans Mono,
            Courier New,
            monospace;
        }
      `}</style>
      <style jsx global>{`
        html,
        body {
          padding: 0;
          margin: 0;
          font-family:
            -apple-system,
            BlinkMacSystemFont,
            Segoe UI,
            Roboto,
            Oxygen,
            Ubuntu,
            Cantarell,
            Fira Sans,
            Droid Sans,
            Helvetica Neue,
            sans-serif;
        }
        * {
          box-sizing: border-box;
        }
      `}</style>
    </div>
  );
}js通过输入文本框从用户处提取输入数字。
使用 HashID 对输入数字编码并显示。


在此处放置许可证密钥:
import {IronPdfGlobalConfig, PdfDocument} from "@ironsoftware/ironpdf";
// Apply your IronPDF license key
IronPdfGlobalConfig.getConfig().licenseKey = "Add Your key here";js在 React 应用程序中集成 Hashids 是保护数据库 ID 或 URL 等敏感数据的实用方法。 通过使用 Hashids,您可以确保标识符的安全性,同时保持在需要时检索原始数据的能力。
无论您是在构建小型应用程序还是复杂的企业系统,Hashids 都能为您提供可靠的解决方案,以增强 React 项目中的数据隐私和安全性,并擅长将递增数字编码为唯一的哈希值。 Hashids 可确保输入数字中的重复模式也能产生独特、不重复的哈希值,从而维护应用程序中的数据完整性和安全性。
IronPDF 是一个强大且多功能的库,适用于寻求在应用程序中实现全面 PDF 生成、操作和管理功能的 node.js 开发人员。 无论您是要构建网络应用程序、桌面软件,还是要将 PDF 功能集成到企业解决方案中。