Generate a random string with good entropy. Generate some random salt and store that. Hash the two together and store that. Share the first random string with the user and don’t store it. Answer from Consibl on reddit.com
🌐
Reddit
reddit.com › r/redditdev › api key credentials
r/redditdev on Reddit: API Key Credentials
May 1, 2022 -

Hey folks, this is baffling me - how do I create a new app/get API credentials?

When I go to /pref/apps I just get a "You are already logged in and will be redirected"

But when I get redirected I end up on the same screen.

Any insights? :-)

Thanks!

🌐
Reddit
reddit.com › r/infinity_for_reddit › if you want to use your own api key
r/Infinity_For_Reddit on Reddit: If You Want to Use Your Own API Key
June 18, 2023 -

Please change ALL of the following:

  • API key

  • Redirect URL

  • User-Agent (in Infinity)

Please don't just change the API key!!!!!!!!! And please use another app name without infinity in it 🥺.

I found many users had made some tutorials about how to use your own API key, like this post, but none of them mentioned the other two things. If you don't change all of them, reddit still knows you are using Infinity, but with your own key.

You can see more info here.

🌐
Data365
data365.co › blog › how-to-get-reddit-api-key
How to Get Reddit API Key: Step-by-Step or Skip-the-Setup? | Data365.co
Not ready? Need a way out? Then skip it all and move to Step 6. Or even shorter way… just fill in the form to get 14-free trial period with Data365 API and already retrieve public Reddit data. So, you’ve got your keys — your Client ID, Client Secret, and User-Agent.
🌐
Reddit
reddit.com › r/learnjavascript › how do i get an api key?
r/learnjavascript on Reddit: How do I get an API key?
June 27, 2024 -

I m having an issue getting an API key for google maps. I just want a map integrated in my Application so a user can search the highlighted places but google seems to ask for a credit card which I dont have. If there are any other open source maps which give API keys. what can I do?

🌐
Reddit
reddit.com › r/learnprogramming › how do i create api keys for my api?
r/learnprogramming on Reddit: How do I create API keys for my API?
June 21, 2021 -

I need to add authentication so that when a user makes a request to the API the API will check if they are able to make requests. I’m not sure how API keys are created or how to make them useable though. Are there any good articles or videos I should watch to learn more about API keys?

Top answer
1 of 3
4
There are a couple of ways to do authentication and authorisation, and it's probably a good idea to read a bit about the different standards - for example, https://oauth.net/2/ or https://openid.net/connect/ . But just to give a rough idea of how these things happen: an API key can be as simple as a random string of characters that identify an authentication object in your database. When creating an API key, you: Generate a random string, e.g. a UUID Create an auth object Store the auth object in your database Store the API key in your database and make it point to your auth object via. a foreign key An auth object can look like this: { email: "[email protected]", username: "Johnnyboi", role: "Admin", canAccessApis: [ '/products', '/users', ... ], canDeleteOtherUsers: true, canDeleteOtherAdmins: false } ... you just put whatever information in there that you want. Then, you give that API key to the user and tell them to append it to every request they make to your API. Typically, the API key is included as a header called something like X-API-KEY. Then, in the backend at your API, on every request you: Extract the header in which the API key should be Look up the API key in your database and get the auth object it points to Use the auth object to check if the user is allowed to do what they want to do You typically write middleware for doing this so you don't have to copy that code for every endpoint you have. This is a very simple way of doing it, but will work just fine. Still, I strongly recommend reading up on some more sophisticated ways of doing it, such as OAuth2 or OIDC.
2 of 3
1
A simple way is to generate them as needed from a combination of a UUID and some extra (truly) random data. For example, I could make a UUID from the date and a 32-bit sequence number: YYYYMMDDSSSSSSSS Then use a truly random source (with entropy) to add like 96 bits (or more!) to that: YYYYMMDDSSSSSSSSRRRRRRRRRRRR Finally I would add a check digit or two so I can use javascript/php/whatever to verify validity without a db hit: YYYYMMDDSSSSSSSSRRRRRRRRRRRRCC Now you just have to make sure to protect the ever loving hell out of the database table that matches an internal ID number to each API key. You may wish to include a version or timestamp with that table so you can invalidate old keys, etc. When I would make registration keys for games I would include even more embedded info in the key, and I would jumble it deterministically. The program I used to generate them was written and used on an air-gapped machine and I would copy over batches of keys using a DVD burner. The key disks went into a safe. Other than all that it's just like any other authentication method. You use session handling code. The big thing is do not store your API keys in the same table as your customer data. Maybe not even the same database if perms are easier that way. I wouldn't even use the customer ID number in the table, instead I would have a third table with one customer id associated with many key id's. The idea being that a customer might have different level APIs for different aspects of their portal, and a hacker would have to breach all three databases to link an API key with that customer. For research: database security, true random numbers, check digits, possibly obfuscation, and session handling.
🌐
Reddit
reddit.com › r/programminghorror › finally figured out how to commit api keys.
r/programminghorror on Reddit: Finally figured out how to commit API keys.
March 31, 2025 - Convert to binary, split it into chunks, read through weird functions which will only give you a link to the actual key. ... Fuck you GitHub, you're not going to stop me from compromising my API keys.
Find elsewhere
🌐
YouTube
youtube.com › watch
How To Get Reddit Api Key 2025! (Full Tutorial) - YouTube
How To Get Reddit Api Key 2025! (Full Tutorial) Today we talk about get reddit api key,reddit api,reddit api how-to,how to use the reddit api
Published   May 20, 2024
🌐
Public APIs
publicapis.io › home › social › reddit
Reddit API — Free Public API | Public APIs Directory
5 days ago - fetch("https://www.reddit.com/api/v1/me.json", { headers: { "Authorization": "bearer YOUR_API_KEY_HERE" } }) .then(response => response.json()) .then(data => { // Use data to display user info console.log(data); }) .catch(error => { console.error(error); }); The Reddit API is a valuable tool for developers who want to build applications that interact with the popular social media platform. By using the examples above, you can get started with exploring the API and building your own projects.
🌐
Reddit
reddit.com › r/redditdev › how to get an api key
r/redditdev on Reddit: how to get an api key
October 9, 2012 -

Hello all Ive been looking around the docs and cannot find how to get an api key. thanks

Top answer
1 of 2
4

You'll need to clarify. We don't have "API keys." If you're writing your reddit client fresh, we recommend using OAuth and that comes with client IDs/secrets.

2 of 2
1

Remember the human. When you communicate online, all you see is a computer screen. When talking to someone you might want to ask yourself "Would I say it to the person's face?" or "Would I get jumped if I said this to a buddy?"

Adhere to the same standards of behavior online that you follow in real life.

Read the rules of a community before making a submission. These are usually found in the sidebar.

Read the reddiquette. Read it again every once in a while. Reddiquette is a living, breathing, working document which may change over time as the community faces new problems in its growth.

Moderate based on quality, not opinion. Well written and interesting content can be worthwhile, even if you disagree with it.

Use proper grammar and spelling. Intelligent discourse requires a standard system of communication. Be open for gentle corrections.

Keep your submission titles factual and opinion free. If it is an outrageous topic, share your crazy outrage in the comment section.

Look for the original source of content, and submit that. Often, a blog will reference another blog, which references another, and so on with everyone displaying ads along the way. Dig through those references and submit a link to the creator, who actually deserves the traffic.

Post to the most appropriate community possible. Also, consider cross posting if the contents fits more communities.

Vote. If you think something contributes to conversation, upvote it. If you think it does not contribute to the subreddit it is posted in or is off-topic in a particular community, downvote it.

Search for duplicates before posting. Redundancy posts add nothing new to previous conversations. That said, sometimes bad timing, a bad title, or just plain bad luck can cause an interesting story to fail to get noticed. Feel free to post something again if you feel that the earlier posting didn't get the attention it deserved and you think you can do better.

Link to the direct version of a media file when the page it was found on doesn't add any value.

Link to canonical and persistent URLs where possible, not temporary pages that might disappear. In particular, use the "permalink" for blog entries, not the blog's index page.

Consider posting constructive criticism / an explanation when you downvote something, and do so carefully and tactfully.

Report any spam you find.

Browse the new submissions page and vote on it. Regard it, perhaps, as a public service.

Actually read an article before you vote on it (as opposed to just basing your vote on the title).

Feel free to post links to your own content (within reason). But if that's all you ever post, or it always seems to get voted down, take a good hard look in the mirror — you just might be a spammer. A widely used rule of thumb is the 9:1 ratio, i.e. only 1 out of every 10 of your submissions should be your own content.

Posts containing explicit material such as nudity, horrible injury etc, add NSFW (Not Safe For Work) for nudity, and tag. However, if something IS safe for work, but has a risqué title, tag as SFW (Safe for Work). Additionally, use your best judgement when adding these tags, in order for everything to go swimmingly.

State your reason for any editing of posts. Edited submissions are marked by an asterisk (*) at the end of the timestamp after three minutes. For example; a simple "Edit: spelling" will help explain. This avoids confusion when a post is edited after a conversation breaks off from it. If you have another thing to add to your original comment, say "Edit: And I also think..." or something along those lines.

Use an "Innocent until proven guilty" mentality. Unless there is obvious proof that a submission is fake, or is whoring karma, please don't say it is. It ruins the experience for not only you, but the millions of people that browse reddit every day.

Read over your submission for mistakes before submitting, especially the title of the submission. Comments and the content of self posts can be edited after being submitted, however, the title of a post can't be. Make sure the facts you provide are accurate to avoid any confusion down the line.

Top answer
1 of 2
24

As of right now, you cannot retrieve a permanent access token. You have 2 options that come close.

The first is to request a "refresh" token when using the standard OAuth flow. That's what you're doing by sending "duration" as "permanent" in your code. The refresh token can be used to automatically retrieve new 1 hour access tokens without user intervention; the only manual steps are on the initial retrieval of the refresh token.

The second alternative, which applies only when writing a script for personal use, is to use the password grant type. The steps are described in more detail on reddit's "OAuth Quick Start" wiki page, but I'll summarize here:

  1. Create an OAuth client (under https://www.reddit.com/prefs/apps) with type = "script"
  2. Make a request to https://www.reddit.com/api/v1/access_token with POST parameters grant_type=password&username=<USERNAME>&password=<PASSWORD>. Send your client ID and secret as HTTP basic authentication. <USERNAME> must be registered as a developer of the OAuth 2 client ID you send.
2 of 2
17

A client_id and client_secret can be generated for a reddit account by going to https://www.reddit.com/prefs/apps and creating an app:


The part I have hidden is my client_id.

Then you can use a client like praw to access reddit e.g. with Python:

import praw
r = praw.Reddit(client_id='insert id here',
                client_secret='insert secret here',
                user_agent='insert user agent')
page = r.subreddit('aww')
top_posts = page.hot(limit=None)
for post in top_posts:
    print(post.title, post.ups)

You could use your current browser's user agent, which can be easily found by google searching "what is my user agent" (among other ways).

🌐
Reddit
reddit.com › r/openbb › how to generate and authorize reddit api credentials for use with the openbb terminal.
r/openBB on Reddit: How to Generate and Authorize Reddit API Credentials for use With the OpenBB Terminal.
September 12, 2022 - From the Main menu, enter the Keys menu. ... Regardless, it should work given all the input values were correct, and with a small caveat for Windows users: Please note: At the time of writing (OpenBB Terminal v. 1.8, Windows Installer-version) ...
🌐
YouTube
youtube.com › watch
Reddit API Tutorial: How to Get Your API Keys in 2024 | Beginner's Guide - YouTube
Learn how to obtain your Reddit API keys with this step-by-step tutorial. Perfect for beginners and developers looking to integrate Reddit functionality into...
Published   July 24, 2024
🌐
Reddit
reddit.com › r/node › how do i issue api keys for my users
r/node on Reddit: How do I issue API keys for my users
June 23, 2023 -

Haven’t been able to find much information on how to do this. I have a service and want to create and issue API keys to my users. I also need to be able to invalidate them. I’m not sure how to do this.

One method I was thinking of was generating a JWT with no expiration and storing in a database. That way I could delete it if they removed the key. And then on every request I would check the database to see if the key matches.

Any suggestions?

🌐
Reddit
reddit.com › r › redditisfun › comments › 144rci9 › workaround_using_an_individuals_api_key_in_app
Workaround: using an individual's API key in app?
November 7, 2022 - I see there's an API key request form for saying "I'm a developer" -- https://www.reddit.com/wiki/api .
🌐
Reddit
reddit.com › r/swift › how do i get an api key?
r/swift on Reddit: How do I get an api key?
April 13, 2022 -

I know I know this is probably a stupid question but please help.

I’m on day 60 of the Hacking with Swift tutorial and really enjoying it.

I was messing around with APIs and want to be able to use this:

post code look up

BUT to use the request URL you need an API key…..

Where do I get one from?!?!

Thank you!!

L

🌐
Reddit
reddit.com › r/chatgpt › using api keys: what you need to know (faq for non-devs)
r/ChatGPT on Reddit: Using API keys: What you need to know (FAQ for non-devs)
October 10, 2023 -

Do I need to be a developer to use an API key? No

Do I need some special knowledge? No, anyone can use it, either through the OpenAI playground (https://platform.openai.com/playground) or other 3rd party apps that allow you to use your key.

Where can I get my own API key? You need to register and log in here: https://platform.openai.com/account/api-keys you also need to set up your payment details with OpenAI to activate your API key.

What's an API key, and why do I need it? ChatGPT is great, but the app has only a limited set of features. OpenAI provides programmatic access to their models via the APIs so devs can use it to build other apps for any use case. An API key is like a personal password. When you use apps with your key, the usage will be billed to your account. The reason why it's become a popular model nowadays is because you only get to pay for what you use and avoid subscriptions.

How and when can I use it? An example could be getbeam.ai, a native ChatGPT app for Mac. This app provides an alternative ChatGPT UI and lets you use your API key. This means you only pay for what you use instead of paying some subscription or monthly fee.

How much does it cost? Is it expensive to use APIs? GPT-3.5 is very cheap; you can use it all day, every day, and your monthly bill will most likely stay under $5

- GPT-4 is more expensive (input: $0.03 / 1K tokens, output: $0.06 / 1K tokens), but it still depends on your usage.

I mostly use GPT-4 as a Google replacement for programming; my prompts are usually quite short, and I don't need 5000-word essays. So, my monthly bill has constantly stayed around $5. But I know some power users who spend $100+/mo

Is it safe to share my API key with 3rd party apps? Yes and No. If some bad actor gets access to your API key two things can happen: they'll use it, and you'll end up paying the bill. They misuse it, and your account can be banned.

The first can be mitigated by setting the spending limit so it will never exceed $20, for example.

If you're using apps from credible sources and have a spending limit on your account, you should be OK.

Can I have multiple API keys? Yes, you can generate multiple API keys. This can be useful if you want to track usage across different applications.

Can APIs replace ChatGPT? Not entirely. When OpenAI rolls out new features to ChatGPT, they're usually unavailable via the APIs immediately. They're not always in sync.

In summary, if you see 3rd party apps saying "Requires OpenAI API Key," it only takes a few clicks to set up. Be careful with how you manage your key to avoid potential misuse. Never share it with random people. Make sure to set the spending limit and only use apps that you can trust.

🌐
Reddit
reddit.com › r/devops › what are you using to create/manage/auth api keys?
r/devops on Reddit: What are you using to create/manage/auth api keys?
May 23, 2024 -

I need to implement some type of API Key system to enable 3rd parties (paying customers) to use apis. I found unkey but not much else in this space, which is kind of surprising. Is everyone really rolling their own solution for this?