- vừa được xem lúc

Ý tưởng triển khai ứng dụng Shorten Url với NextJS

0 0 22

Người đăng: Bun

Theo Viblo Asia

Việc chia sẻ URL là một việc diễn ra thường xuyên. Tuy nhiên, các URL dài và cồng kềnh có thể gây khó khăn cho người dùng, đặc biệt là khi chia sẻ trên các nền tảng mạng xã hội. Để giải quyết vấn đề này, các ứng dụng rút gọn URL ra đời. Các ứng dụng này giúp rút gọn URL dài thành các URL ngắn gọn và dễ nhớ hơn.

Một số ứng dụng rút gọn URL phổ biến hiện nay mà mình biết bao gồm Bit.ly, Tiny.url, Goo.gl,... Tuy nhiên, các ứng dụng này thường yêu cầu người dùng trả phí để sử dụng tính năng thêm domain name.

Nếu bạn muốn sở hữu một ứng dụng rút gọn URL mang thương hiệu cá nhân mà không phải trả phí, bạn có thể tự tạo ứng dụng của riêng mình.

Trong bài viết này, mình sẽ chia sẻ cách tạo ứng dụng rút gọn URL với Next.js.

shortenUrl

Step 1: Tạo NextJS project

Chạy lệnh bên dưới để tạo dự án Next.js mới

npx create-next-app shorten-url-app
cd shorten-url-app

Cấu trúc files

Xác định các files cần thiết cho dự án. Thông thường, bạn sẽ cần 1 file điều hướng đến trang chủ, 1 file truy cập trang rút ​​ngắn URL để parse shorten URL và 1 file xử lí chuyển hướng đến URL gốc.

Tạo một tệp có tên app/index.js cho trang chủ, một tệp có tên app/shorten/page.js để rút ngắn URL và một tệp có tên app/not-found.js để chuyển hướng.

Step 2: Xây dựng giao diện

Thiết kế giao diện người dùng. Bên dưới là ví dụ cơ bản để giúp bạn bắt đầu nhưng bạn có thể tùy chỉnh nó theo thẩm mĩ riêng của mình.

Ở bài viết này mình sẽ tập trung vào trang chức năng, nên giờ bắt đầu xử lý với shorten.js file

// app/shorten/page.js
import React, { useState } from 'react'; export default function Shorten() { const [originalURL, setOriginalURL] = useState(''); const [shortenedURL, setShortenedURL] = useState(''); const handleShortenURL = () => { // URL shortening logic - handle in next step }; return ( <div> <h1>URL Shortener</h1> <input type="text" placeholder="Nhập URL" value={originalURL} onChange={(e) => setOriginalURL(e.target.value)} onSubmit={handleShortenURL} /> <button onClick={handleShortenURL}>Rút gọn</button> {shortenedURL && ( <div className="flex justify-between items-center"> <p> URL đã rút gọn: <a className="text-md text-sky-500" href={shortenedURL}>{shortenedURL}</a> </p> <div className="w-fit rounded-md p-2 my-2 border hover:bg-slate-600"> <BunCopyButton linkValue={shortenedURL} /> </div> </div> )} </div> );
} 

UI

Step 3: Lưu trữ

Bạn có thể xây dựng DB để lưu trữ, nhưng để đơn giản dự án nhất có thể mình tạo thêm thư mục /data rồi lưu dữ liệu dưới dạng json

Cấu trúc json được lưu như vầy:

[ { "origin_url": "https://example.com/long_link01", "short_id": "DAVCZ15KJ", "description": "This is the link of task Monday", "created_date": "11/11/2023" }, { "origin_url": "https://example.com/long_link02", "short_id": "AFDA435VF", "description": "This is the link of task on Freshdesk", "created_date": "11/11/2023" }
]

Step 4: Xử lý URL Shortening Logic

Tạo shorten URL

Mình dùng package shortid để tạo một chuỗi rút gọn ngẫu nhiên cho url

npm install shortid
// app/shorten/page.js
import shortid from 'shortid'
import { sql } from '@vercel/postgres' // ... const [originalURL, setOriginalURL] = useState('');
const [shortenedURL, setShortenedURL] = useState('');
const [shortened, setShortened] = useState(''); useEffect(() => { if (shortened) { setShortenedURL(`https://your_domain.com/${shortened}`); // Lưu thông tin sau khi đã xử lý vào file json postData(); }
}, [shortened]); const handleShortenURL = () => { if (!originalURL || !isValidUrl(originalURL)) { return false; } setShortened(shortid.generate()); // Generate a short ID
} const isValidUrl = (string) => { try { new URL(string); return true; } catch (err) { return false; }
} const postData = async () => {} // Handle post request

Điều hướng Shorten URL đến URL gốc

Dựa theo cấu trúc thư mục của dự án NextJS, tất cả đường dẫn ko xác định sẽ chạy vào file not-found.js, nên mình sẽ tạo file not-found.js và xử lý việc điều hướng các shorten URL.

Ý tưởng là nạp dữ liệu từ file json sau đó so sánh shortenId để lấy url gốc, rồi điều hướng đến url gốc bằng navigation

// app/not-found.js
import { useEffect } from 'react';
import { usePathname, redirect } from 'next/navigation'; const Redirect = () => { const pathname = usePathname() useEffect(() => { links.forEach(item => { if(item.short_id == pathname.replace('/','')) { redirect(item.origin_url) } }); }) return ( <div className="text-white">Đường dẫn không tìm thấy!~</div> )
}; export default Redirect;

Replace https://your_domain.com/ with your own domain when deploying your app.

Step 4: Deploy dự án Next.js

Có rất nhiều nền tảng để deploy, nhưng lí do vì sao ngay từ ban đầu mình chọn NextJS là vì nó có thằng vercel đứng sau. Việc deploy dự án với Vercel rất dễ dàng nên đây là một hint mình gợi ý để deploy dự án.

Ngoài vercel thì còn nhiều thằng khác như Netlify, hay là Heroku

Conclusion

If you like this post and my open source, don't forget to give me support (clapp, upvote).

Medium post: medium.com/p/17ae9152a74f

Author: bunhere.com

I am always looking for feedback on my writing, so please let me know what you think. ❤️

Bình luận

Bài viết tương tự

- vừa được xem lúc

Viết một chiếc app quản lý Hạn sử dụng của thực phẩm

Mở đầu. Tôi là 1 kỹ sư công nghệ thông tin mới ra trường. Trong thời gian học Đại học, từ năm 1 tới năm 4, tôi đi làm thêm tại TSUTAYA (chuỗi cửa hàng bán sách, video...v.v nổi tiếng bên Nhật). Về chiếc App tôi đã phát triển. App tôi phát triển là Web App giúp quản lý hạn sử dụng của đồ ăn.

0 0 52

- vừa được xem lúc

Routing trong Next.js

Trước đó bạn có thể đang tò mò về Next.js, vào đây luôn bạn ơi. (go). .

1 0 56

- vừa được xem lúc

Cài đặt chuyển đổi ngôn ngữ trong một project NextJS

Ở phiên bản Nextjs Version 10 mới đây, việc sử dụng i18n đã trở nên dễ dàng hơn qua tính nâng cao là Internationalized Routing. Cài đặt cấu hình cơ bản. Tại file next.config.

0 0 73

- vừa được xem lúc

Cấu hình eslint airbnb, prettier cho dự next.js sử dụng typescript

Chào mọi, mình đã quay lại đây. Hôm nay mình sẽ đem đến một chủ đề linter cụ thể cấu hình eslint cho dự án next.

0 0 195

- vừa được xem lúc

Handling custom page navigation on Next.js

Last month we discussed about different kind of routing on Next.js. Here's a short example of creating a component that moves the user to next page. import { useRouter } from 'next/router'.

0 0 87

- vừa được xem lúc

Next Image một feature, một nâng cấp tuyệt vời version nextjs 10

NextJS đã cho ra mắt version 10 cách đây 2 tháng với hơn 20 fearture nâng cấp đáng giá. Chúng ta có thể kể ra những features nổi bật như. . Next/Image: với khẳ năng render image cho các kích thước màn hình tương ứng.

0 0 62